Merge branch 'tauri' of https://git.ez-pp.farm/EZPPFarm/EZPPLauncher into tauri
This commit is contained in:
		
							
								
								
									
										9
									
								
								.prettierignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								.prettierignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| # Package Managers | ||||
| package-lock.json | ||||
| pnpm-lock.yaml | ||||
| yarn.lock | ||||
| bun.lock | ||||
| bun.lockb | ||||
|  | ||||
| # Miscellaneous | ||||
| /static/ | ||||
| @@ -9,8 +9,7 @@ | ||||
|   "tabWidth": 2, | ||||
|   "useTabs": false, | ||||
|   "bracketSpacing": true, | ||||
|   "svelteBracketNewLine": true, | ||||
|   "plugins": ["prettier-plugin-svelte"], | ||||
|   "plugins": ["prettier-plugin-svelte", "prettier-plugin-rust"], | ||||
|   "overrides": [ | ||||
|     { | ||||
|       "files": "*.svelte", | ||||
|   | ||||
							
								
								
									
										7
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							| @@ -2,6 +2,11 @@ | ||||
|   "recommendations": [ | ||||
|     "svelte.svelte-vscode", | ||||
|     "tauri-apps.tauri-vscode", | ||||
|     "rust-lang.rust-analyzer" | ||||
|     "rust-lang.rust-analyzer", | ||||
|     "esbenp.prettier-vscode", | ||||
|     "fill-labs.dependi", | ||||
|     "mylesmurphy.prettify-ts", | ||||
|     "edwinhuish.better-comments-next", | ||||
|     "dbaeumer.vscode-eslint" | ||||
|   ] | ||||
| } | ||||
|   | ||||
							
								
								
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,7 @@ | ||||
| { | ||||
|   "svelte.enable-ts-plugin": true | ||||
|   "svelte.enable-ts-plugin": true, | ||||
|   "editor.defaultFormatter": "esbenp.prettier-vscode", | ||||
|   "[rust]":{ | ||||
|     "editor.defaultFormatter": "rust-lang.rust-analyzer" | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										222
									
								
								bun.lock
									
									
									
									
									
								
							
							
						
						
									
										222
									
								
								bun.lock
									
									
									
									
									
								
							| @@ -22,10 +22,13 @@ | ||||
|         "lucide-svelte": "0.523.0", | ||||
|         "osu-classes": "3.1.0", | ||||
|         "osu-parsers": "4.1.7", | ||||
|         "prettier-plugin-rust": "^0.1.9", | ||||
|         "radix-icons-svelte": "1.2.1", | ||||
|         "svelte-confetti": "^2.0.0", | ||||
|       }, | ||||
|       "devDependencies": { | ||||
|         "@eslint/compat": "^1.2.5", | ||||
|         "@eslint/js": "^9.18.0", | ||||
|         "@lucide/svelte": "^0.482.0", | ||||
|         "@sveltejs/adapter-static": "3.0.8", | ||||
|         "@sveltejs/kit": "2.22.2", | ||||
| @@ -35,9 +38,13 @@ | ||||
|         "autoprefixer": "10.4.21", | ||||
|         "bits-ui": "^1.4.7", | ||||
|         "clsx": "2.1.1", | ||||
|         "eslint": "^9.18.0", | ||||
|         "eslint-config-prettier": "^10.0.1", | ||||
|         "eslint-plugin-svelte": "^3.0.0", | ||||
|         "globals": "^16.0.0", | ||||
|         "mode-watcher": "^1.0.6", | ||||
|         "prettier": "^3.6.1", | ||||
|         "prettier-plugin-svelte": "^3.4.0", | ||||
|         "prettier": "^3.4.2", | ||||
|         "prettier-plugin-svelte": "^3.3.3", | ||||
|         "sass-embedded": "1.89.2", | ||||
|         "svelte": "5.34.8", | ||||
|         "svelte-check": "4.2.2", | ||||
| @@ -48,6 +55,7 @@ | ||||
|         "tailwindcss-animate": "1.0.7", | ||||
|         "tslib": "2.8.1", | ||||
|         "typescript": "5.8.3", | ||||
|         "typescript-eslint": "^8.20.0", | ||||
|         "vite": "7.0.0", | ||||
|         "vite-plugin-devtools-json": "^0.2.0", | ||||
|       }, | ||||
| @@ -114,6 +122,26 @@ | ||||
|  | ||||
|     "@esbuild/win32-x64": ["@esbuild/win32-x64@0.25.5", "", { "os": "win32", "cpu": "x64" }, "sha512-TXv6YnJ8ZMVdX+SXWVBo/0p8LTcrUYngpWjvm91TMjjBQii7Oz11Lw5lbDV5Y0TzuhSJHwiH4hEtC1I42mMS0g=="], | ||||
|  | ||||
|     "@eslint-community/eslint-utils": ["@eslint-community/eslint-utils@4.7.0", "", { "dependencies": { "eslint-visitor-keys": "^3.4.3" }, "peerDependencies": { "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" } }, "sha512-dyybb3AcajC7uha6CvhdVRJqaKyn7w2YKqKyAN37NKYgZT36w+iRb0Dymmc5qEJ549c/S31cMMSFd75bteCpCw=="], | ||||
|  | ||||
|     "@eslint-community/regexpp": ["@eslint-community/regexpp@4.12.1", "", {}, "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ=="], | ||||
|  | ||||
|     "@eslint/compat": ["@eslint/compat@1.3.1", "", { "peerDependencies": { "eslint": "^8.40 || 9" }, "optionalPeers": ["eslint"] }, "sha512-k8MHony59I5EPic6EQTCNOuPoVBnoYXkP+20xvwFjN7t0qI3ImyvyBgg+hIVPwC8JaxVjjUZld+cLfBLFDLucg=="], | ||||
|  | ||||
|     "@eslint/config-array": ["@eslint/config-array@0.21.0", "", { "dependencies": { "@eslint/object-schema": "^2.1.6", "debug": "^4.3.1", "minimatch": "^3.1.2" } }, "sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ=="], | ||||
|  | ||||
|     "@eslint/config-helpers": ["@eslint/config-helpers@0.3.0", "", {}, "sha512-ViuymvFmcJi04qdZeDc2whTHryouGcDlaxPqarTD0ZE10ISpxGUVZGZDx4w01upyIynL3iu6IXH2bS1NhclQMw=="], | ||||
|  | ||||
|     "@eslint/core": ["@eslint/core@0.14.0", "", { "dependencies": { "@types/json-schema": "^7.0.15" } }, "sha512-qIbV0/JZr7iSDjqAc60IqbLdsj9GDt16xQtWD+B78d/HAlvysGdZZ6rpJHGAc2T0FQx1X6thsSPdnoiGKdNtdg=="], | ||||
|  | ||||
|     "@eslint/eslintrc": ["@eslint/eslintrc@3.3.1", "", { "dependencies": { "ajv": "^6.12.4", "debug": "^4.3.2", "espree": "^10.0.1", "globals": "^14.0.0", "ignore": "^5.2.0", "import-fresh": "^3.2.1", "js-yaml": "^4.1.0", "minimatch": "^3.1.2", "strip-json-comments": "^3.1.1" } }, "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ=="], | ||||
|  | ||||
|     "@eslint/js": ["@eslint/js@9.30.1", "", {}, "sha512-zXhuECFlyep42KZUhWjfvsmXGX39W8K8LFb8AWXM9gSV9dQB+MrJGLKvW6Zw0Ggnbpw0VHTtrhFXYe3Gym18jg=="], | ||||
|  | ||||
|     "@eslint/object-schema": ["@eslint/object-schema@2.1.6", "", {}, "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA=="], | ||||
|  | ||||
|     "@eslint/plugin-kit": ["@eslint/plugin-kit@0.3.3", "", { "dependencies": { "@eslint/core": "^0.15.1", "levn": "^0.4.1" } }, "sha512-1+WqvgNMhmlAambTvT3KPtCl/Ibr68VldY2XY40SL1CE0ZXiakFR/cbTspaF5HsnpDMvcYYoJHfl4980NBjGag=="], | ||||
|  | ||||
|     "@floating-ui/core": ["@floating-ui/core@1.7.1", "", { "dependencies": { "@floating-ui/utils": "^0.2.9" } }, "sha512-azI0DrjMMfIug/ExbBaeDVJXcY0a7EPvPjb2xAJPa4HeimBX+Z18HK8QQR3jb6356SnDDdxx+hinMLcJEDdOjw=="], | ||||
|  | ||||
|     "@floating-ui/dom": ["@floating-ui/dom@1.7.1", "", { "dependencies": { "@floating-ui/core": "^1.7.1", "@floating-ui/utils": "^0.2.9" } }, "sha512-cwsmW/zyw5ltYTUeeYJ60CnQuPqmGwuGVhG9w0PRaRKkAyi38BT5CKrpIbb+jtahSwUl04cWzSx9ZOIxeS6RsQ=="], | ||||
| @@ -124,6 +152,14 @@ | ||||
|  | ||||
|     "@fontsource/space-mono": ["@fontsource/space-mono@5.2.8", "", {}, "sha512-25X0fg1+kxxLes9/c6AozhrrAuBW1uLaOL584IRg4DZxVxNOMzcS3mHS1UtmsyTwtU2HpiIt9Kv23Q+7xQO+hg=="], | ||||
|  | ||||
|     "@humanfs/core": ["@humanfs/core@0.19.1", "", {}, "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA=="], | ||||
|  | ||||
|     "@humanfs/node": ["@humanfs/node@0.16.6", "", { "dependencies": { "@humanfs/core": "^0.19.1", "@humanwhocodes/retry": "^0.3.0" } }, "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw=="], | ||||
|  | ||||
|     "@humanwhocodes/module-importer": ["@humanwhocodes/module-importer@1.0.1", "", {}, "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA=="], | ||||
|  | ||||
|     "@humanwhocodes/retry": ["@humanwhocodes/retry@0.4.3", "", {}, "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ=="], | ||||
|  | ||||
|     "@internationalized/date": ["@internationalized/date@3.8.2", "", { "dependencies": { "@swc/helpers": "^0.5.0" } }, "sha512-/wENk7CbvLbkUvX1tu0mwq49CVkkWpkXubGel6birjRPyo6uQ4nQpnq5xZu823zRCwwn82zgHrvgF1vZyvmVgA=="], | ||||
|  | ||||
|     "@isaacs/cliui": ["@isaacs/cliui@8.0.2", "", { "dependencies": { "string-width": "^5.1.2", "string-width-cjs": "npm:string-width@^4.2.0", "strip-ansi": "^7.0.1", "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", "wrap-ansi": "^8.1.0", "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" } }, "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA=="], | ||||
| @@ -246,15 +282,41 @@ | ||||
|  | ||||
|     "@types/estree": ["@types/estree@1.0.8", "", {}, "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w=="], | ||||
|  | ||||
|     "@types/json-schema": ["@types/json-schema@7.0.15", "", {}, "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA=="], | ||||
|  | ||||
|     "@types/node": ["@types/node@20.19.1", "", { "dependencies": { "undici-types": "~6.21.0" } }, "sha512-jJD50LtlD2dodAEO653i3YF04NWak6jN3ky+Ri3Em3mGR39/glWiboM/IePaRbgwSfqM1TpGXfAg8ohn/4dTgA=="], | ||||
|  | ||||
|     "@typescript-eslint/eslint-plugin": ["@typescript-eslint/eslint-plugin@8.35.1", "", { "dependencies": { "@eslint-community/regexpp": "^4.10.0", "@typescript-eslint/scope-manager": "8.35.1", "@typescript-eslint/type-utils": "8.35.1", "@typescript-eslint/utils": "8.35.1", "@typescript-eslint/visitor-keys": "8.35.1", "graphemer": "^1.4.0", "ignore": "^7.0.0", "natural-compare": "^1.4.0", "ts-api-utils": "^2.1.0" }, "peerDependencies": { "@typescript-eslint/parser": "^8.35.1", "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <5.9.0" } }, "sha512-9XNTlo7P7RJxbVeICaIIIEipqxLKguyh+3UbXuT2XQuFp6d8VOeDEGuz5IiX0dgZo8CiI6aOFLg4e8cF71SFVg=="], | ||||
|  | ||||
|     "@typescript-eslint/parser": ["@typescript-eslint/parser@8.35.1", "", { "dependencies": { "@typescript-eslint/scope-manager": "8.35.1", "@typescript-eslint/types": "8.35.1", "@typescript-eslint/typescript-estree": "8.35.1", "@typescript-eslint/visitor-keys": "8.35.1", "debug": "^4.3.4" }, "peerDependencies": { "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <5.9.0" } }, "sha512-3MyiDfrfLeK06bi/g9DqJxP5pV74LNv4rFTyvGDmT3x2p1yp1lOd+qYZfiRPIOf/oON+WRZR5wxxuF85qOar+w=="], | ||||
|  | ||||
|     "@typescript-eslint/project-service": ["@typescript-eslint/project-service@8.35.1", "", { "dependencies": { "@typescript-eslint/tsconfig-utils": "^8.35.1", "@typescript-eslint/types": "^8.35.1", "debug": "^4.3.4" }, "peerDependencies": { "typescript": ">=4.8.4 <5.9.0" } }, "sha512-VYxn/5LOpVxADAuP3NrnxxHYfzVtQzLKeldIhDhzC8UHaiQvYlXvKuVho1qLduFbJjjy5U5bkGwa3rUGUb1Q6Q=="], | ||||
|  | ||||
|     "@typescript-eslint/scope-manager": ["@typescript-eslint/scope-manager@8.35.1", "", { "dependencies": { "@typescript-eslint/types": "8.35.1", "@typescript-eslint/visitor-keys": "8.35.1" } }, "sha512-s/Bpd4i7ht2934nG+UoSPlYXd08KYz3bmjLEb7Ye1UVob0d1ENiT3lY8bsCmik4RqfSbPw9xJJHbugpPpP5JUg=="], | ||||
|  | ||||
|     "@typescript-eslint/tsconfig-utils": ["@typescript-eslint/tsconfig-utils@8.35.1", "", { "peerDependencies": { "typescript": ">=4.8.4 <5.9.0" } }, "sha512-K5/U9VmT9dTHoNowWZpz+/TObS3xqC5h0xAIjXPw+MNcKV9qg6eSatEnmeAwkjHijhACH0/N7bkhKvbt1+DXWQ=="], | ||||
|  | ||||
|     "@typescript-eslint/type-utils": ["@typescript-eslint/type-utils@8.35.1", "", { "dependencies": { "@typescript-eslint/typescript-estree": "8.35.1", "@typescript-eslint/utils": "8.35.1", "debug": "^4.3.4", "ts-api-utils": "^2.1.0" }, "peerDependencies": { "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <5.9.0" } }, "sha512-HOrUBlfVRz5W2LIKpXzZoy6VTZzMu2n8q9C2V/cFngIC5U1nStJgv0tMV4sZPzdf4wQm9/ToWUFPMN9Vq9VJQQ=="], | ||||
|  | ||||
|     "@typescript-eslint/types": ["@typescript-eslint/types@8.35.1", "", {}, "sha512-q/O04vVnKHfrrhNAscndAn1tuQhIkwqnaW+eu5waD5IPts2eX1dgJxgqcPx5BX109/qAz7IG6VrEPTOYKCNfRQ=="], | ||||
|  | ||||
|     "@typescript-eslint/typescript-estree": ["@typescript-eslint/typescript-estree@8.35.1", "", { "dependencies": { "@typescript-eslint/project-service": "8.35.1", "@typescript-eslint/tsconfig-utils": "8.35.1", "@typescript-eslint/types": "8.35.1", "@typescript-eslint/visitor-keys": "8.35.1", "debug": "^4.3.4", "fast-glob": "^3.3.2", "is-glob": "^4.0.3", "minimatch": "^9.0.4", "semver": "^7.6.0", "ts-api-utils": "^2.1.0" }, "peerDependencies": { "typescript": ">=4.8.4 <5.9.0" } }, "sha512-Vvpuvj4tBxIka7cPs6Y1uvM7gJgdF5Uu9F+mBJBPY4MhvjrjWGK4H0lVgLJd/8PWZ23FTqsaJaLEkBCFUk8Y9g=="], | ||||
|  | ||||
|     "@typescript-eslint/utils": ["@typescript-eslint/utils@8.35.1", "", { "dependencies": { "@eslint-community/eslint-utils": "^4.7.0", "@typescript-eslint/scope-manager": "8.35.1", "@typescript-eslint/types": "8.35.1", "@typescript-eslint/typescript-estree": "8.35.1" }, "peerDependencies": { "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <5.9.0" } }, "sha512-lhnwatFmOFcazAsUm3ZnZFpXSxiwoa1Lj50HphnDe1Et01NF4+hrdXONSUHIcbVu2eFb1bAf+5yjXkGVkXBKAQ=="], | ||||
|  | ||||
|     "@typescript-eslint/visitor-keys": ["@typescript-eslint/visitor-keys@8.35.1", "", { "dependencies": { "@typescript-eslint/types": "8.35.1", "eslint-visitor-keys": "^4.2.1" } }, "sha512-VRwixir4zBWCSTP/ljEo091lbpypz57PoeAQ9imjG+vbeof9LplljsL1mos4ccG6H9IjfrVGM359RozUnuFhpw=="], | ||||
|  | ||||
|     "acorn": ["acorn@8.15.0", "", { "bin": { "acorn": "bin/acorn" } }, "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg=="], | ||||
|  | ||||
|     "acorn-jsx": ["acorn-jsx@5.3.2", "", { "peerDependencies": { "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" } }, "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ=="], | ||||
|  | ||||
|     "ajv": ["ajv@6.12.6", "", { "dependencies": { "fast-deep-equal": "^3.1.1", "fast-json-stable-stringify": "^2.0.0", "json-schema-traverse": "^0.4.1", "uri-js": "^4.2.2" } }, "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g=="], | ||||
|  | ||||
|     "animejs": ["animejs@4.0.2", "", {}, "sha512-f0L/kSya2RF23iMSF/VO01pMmLwlAFoiQeNAvBXhEyLzIPd2/QTBRatwGUqkVCC6seaAJYzAkGir55N4SL+h3A=="], | ||||
|  | ||||
|     "ansi-regex": ["ansi-regex@6.1.0", "", {}, "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA=="], | ||||
|  | ||||
|     "ansi-styles": ["ansi-styles@6.2.1", "", {}, "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug=="], | ||||
|     "ansi-styles": ["ansi-styles@4.3.0", "", { "dependencies": { "color-convert": "^2.0.1" } }, "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg=="], | ||||
|  | ||||
|     "any-promise": ["any-promise@1.3.0", "", {}, "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A=="], | ||||
|  | ||||
| @@ -262,6 +324,8 @@ | ||||
|  | ||||
|     "arg": ["arg@5.0.2", "", {}, "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg=="], | ||||
|  | ||||
|     "argparse": ["argparse@2.0.1", "", {}, "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q=="], | ||||
|  | ||||
|     "aria-query": ["aria-query@5.3.2", "", {}, "sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw=="], | ||||
|  | ||||
|     "autoprefixer": ["autoprefixer@10.4.21", "", { "dependencies": { "browserslist": "^4.24.4", "caniuse-lite": "^1.0.30001702", "fraction.js": "^4.3.7", "normalize-range": "^0.1.2", "picocolors": "^1.1.1", "postcss-value-parser": "^4.2.0" }, "peerDependencies": { "postcss": "^8.1.0" }, "bin": { "autoprefixer": "bin/autoprefixer" } }, "sha512-O+A6LWV5LDHSJD3LjHYoNi4VLsj/Whi7k6zG12xTYaU4cQ8oxQGckXNX8cRHK5yOZ/ppVHe0ZBXGzSV9jXdVbQ=="], | ||||
| @@ -276,7 +340,7 @@ | ||||
|  | ||||
|     "bits-ui": ["bits-ui@1.8.0", "", { "dependencies": { "@floating-ui/core": "^1.6.4", "@floating-ui/dom": "^1.6.7", "@internationalized/date": "^3.5.6", "css.escape": "^1.5.1", "esm-env": "^1.1.2", "runed": "^0.23.2", "svelte-toolbelt": "^0.7.1", "tabbable": "^6.2.0" }, "peerDependencies": { "svelte": "^5.11.0" } }, "sha512-CXD6Orp7l8QevNDcRPLXc/b8iMVgxDWT2LyTwsdLzJKh9CxesOmPuNePSPqAxKoT59FIdU4aFPS1k7eBdbaCxg=="], | ||||
|  | ||||
|     "brace-expansion": ["brace-expansion@2.0.2", "", { "dependencies": { "balanced-match": "^1.0.0" } }, "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ=="], | ||||
|     "brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], | ||||
|  | ||||
|     "braces": ["braces@3.0.3", "", { "dependencies": { "fill-range": "^7.1.1" } }, "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA=="], | ||||
|  | ||||
| @@ -286,10 +350,14 @@ | ||||
|  | ||||
|     "buffer-builder": ["buffer-builder@0.2.0", "", {}, "sha512-7VPMEPuYznPSoR21NE1zvd2Xna6c/CloiZCfcMXR1Jny6PjX0N4Nsa38zcBFo/FMK+BlA+FLKbJCQ0i2yxp+Xg=="], | ||||
|  | ||||
|     "callsites": ["callsites@3.1.0", "", {}, "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ=="], | ||||
|  | ||||
|     "camelcase-css": ["camelcase-css@2.0.1", "", {}, "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA=="], | ||||
|  | ||||
|     "caniuse-lite": ["caniuse-lite@1.0.30001726", "", {}, "sha512-VQAUIUzBiZ/UnlM28fSp2CRF3ivUn1BWEvxMcVTNwpw91Py1pGbPIyIKtd+tzct9C3ouceCVdGAXxZOpZAsgdw=="], | ||||
|  | ||||
|     "chalk": ["chalk@4.1.2", "", { "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" } }, "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA=="], | ||||
|  | ||||
|     "chokidar": ["chokidar@4.0.3", "", { "dependencies": { "readdirp": "^4.0.1" } }, "sha512-Qgzu8kfBvo+cA4962jnP1KkS6Dop5NS6g7R5LFYJr4b8Ub94PPQXUksCw9PvXoeXPRRddRNC5C1JQUR2SMGtnA=="], | ||||
|  | ||||
|     "clsx": ["clsx@2.1.1", "", {}, "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA=="], | ||||
| @@ -302,6 +370,8 @@ | ||||
|  | ||||
|     "commander": ["commander@4.1.1", "", {}, "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA=="], | ||||
|  | ||||
|     "concat-map": ["concat-map@0.0.1", "", {}, "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="], | ||||
|  | ||||
|     "cookie": ["cookie@0.6.0", "", {}, "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw=="], | ||||
|  | ||||
|     "cross-spawn": ["cross-spawn@7.0.6", "", { "dependencies": { "path-key": "^3.1.0", "shebang-command": "^2.0.0", "which": "^2.0.1" } }, "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA=="], | ||||
| @@ -316,6 +386,8 @@ | ||||
|  | ||||
|     "debug": ["debug@4.4.1", "", { "dependencies": { "ms": "^2.1.3" } }, "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ=="], | ||||
|  | ||||
|     "deep-is": ["deep-is@0.1.4", "", {}, "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ=="], | ||||
|  | ||||
|     "deepmerge": ["deepmerge@4.3.1", "", {}, "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A=="], | ||||
|  | ||||
|     "devalue": ["devalue@5.1.1", "", {}, "sha512-maua5KUiapvEwiEAe+XnlZ3Rh0GD+qI1J/nb9vrJc3muPXvcF/8gXYTWF76+5DAqHyDUtOIImEuo0YKE9mshVw=="], | ||||
| @@ -334,18 +406,54 @@ | ||||
|  | ||||
|     "escalade": ["escalade@3.2.0", "", {}, "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA=="], | ||||
|  | ||||
|     "escape-string-regexp": ["escape-string-regexp@4.0.0", "", {}, "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA=="], | ||||
|  | ||||
|     "eslint": ["eslint@9.30.1", "", { "dependencies": { "@eslint-community/eslint-utils": "^4.2.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.0", "@eslint/config-helpers": "^0.3.0", "@eslint/core": "^0.14.0", "@eslint/eslintrc": "^3.3.1", "@eslint/js": "9.30.1", "@eslint/plugin-kit": "^0.3.1", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", "@types/estree": "^1.0.6", "@types/json-schema": "^7.0.15", "ajv": "^6.12.4", "chalk": "^4.0.0", "cross-spawn": "^7.0.6", "debug": "^4.3.2", "escape-string-regexp": "^4.0.0", "eslint-scope": "^8.4.0", "eslint-visitor-keys": "^4.2.1", "espree": "^10.4.0", "esquery": "^1.5.0", "esutils": "^2.0.2", "fast-deep-equal": "^3.1.3", "file-entry-cache": "^8.0.0", "find-up": "^5.0.0", "glob-parent": "^6.0.2", "ignore": "^5.2.0", "imurmurhash": "^0.1.4", "is-glob": "^4.0.0", "json-stable-stringify-without-jsonify": "^1.0.1", "lodash.merge": "^4.6.2", "minimatch": "^3.1.2", "natural-compare": "^1.4.0", "optionator": "^0.9.3" }, "peerDependencies": { "jiti": "*" }, "optionalPeers": ["jiti"], "bin": { "eslint": "bin/eslint.js" } }, "sha512-zmxXPNMOXmwm9E0yQLi5uqXHs7uq2UIiqEKo3Gq+3fwo1XrJ+hijAZImyF7hclW3E6oHz43Yk3RP8at6OTKflQ=="], | ||||
|  | ||||
|     "eslint-config-prettier": ["eslint-config-prettier@10.1.5", "", { "peerDependencies": { "eslint": ">=7.0.0" }, "bin": { "eslint-config-prettier": "bin/cli.js" } }, "sha512-zc1UmCpNltmVY34vuLRV61r1K27sWuX39E+uyUnY8xS2Bex88VV9cugG+UZbRSRGtGyFboj+D8JODyme1plMpw=="], | ||||
|  | ||||
|     "eslint-plugin-svelte": ["eslint-plugin-svelte@3.10.1", "", { "dependencies": { "@eslint-community/eslint-utils": "^4.6.1", "@jridgewell/sourcemap-codec": "^1.5.0", "esutils": "^2.0.3", "globals": "^16.0.0", "known-css-properties": "^0.37.0", "postcss": "^8.4.49", "postcss-load-config": "^3.1.4", "postcss-safe-parser": "^7.0.0", "semver": "^7.6.3", "svelte-eslint-parser": "^1.2.0" }, "peerDependencies": { "eslint": "^8.57.1 || ^9.0.0", "svelte": "^3.37.0 || ^4.0.0 || ^5.0.0" }, "optionalPeers": ["svelte"] }, "sha512-csCh2x0ge/DugXC7dCANh46Igi7bjMZEy6rHZCdS13AoGVJSu7a90Kru3I8oMYLGEemPRE1hQXadxvRPVMAAXQ=="], | ||||
|  | ||||
|     "eslint-scope": ["eslint-scope@8.4.0", "", { "dependencies": { "esrecurse": "^4.3.0", "estraverse": "^5.2.0" } }, "sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg=="], | ||||
|  | ||||
|     "eslint-visitor-keys": ["eslint-visitor-keys@4.2.1", "", {}, "sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ=="], | ||||
|  | ||||
|     "esm-env": ["esm-env@1.2.2", "", {}, "sha512-Epxrv+Nr/CaL4ZcFGPJIYLWFom+YeV1DqMLHJoEd9SYRxNbaFruBwfEX/kkHUJf55j2+TUbmDcmuilbP1TmXHA=="], | ||||
|  | ||||
|     "espree": ["espree@10.4.0", "", { "dependencies": { "acorn": "^8.15.0", "acorn-jsx": "^5.3.2", "eslint-visitor-keys": "^4.2.1" } }, "sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ=="], | ||||
|  | ||||
|     "esquery": ["esquery@1.6.0", "", { "dependencies": { "estraverse": "^5.1.0" } }, "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg=="], | ||||
|  | ||||
|     "esrap": ["esrap@1.4.9", "", { "dependencies": { "@jridgewell/sourcemap-codec": "^1.4.15" } }, "sha512-3OMlcd0a03UGuZpPeUC1HxR3nA23l+HEyCiZw3b3FumJIN9KphoGzDJKMXI1S72jVS1dsenDyQC0kJlO1U9E1g=="], | ||||
|  | ||||
|     "esrecurse": ["esrecurse@4.3.0", "", { "dependencies": { "estraverse": "^5.2.0" } }, "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag=="], | ||||
|  | ||||
|     "estraverse": ["estraverse@5.3.0", "", {}, "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA=="], | ||||
|  | ||||
|     "esutils": ["esutils@2.0.3", "", {}, "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g=="], | ||||
|  | ||||
|     "fast-deep-equal": ["fast-deep-equal@3.1.3", "", {}, "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q=="], | ||||
|  | ||||
|     "fast-glob": ["fast-glob@3.3.3", "", { "dependencies": { "@nodelib/fs.stat": "^2.0.2", "@nodelib/fs.walk": "^1.2.3", "glob-parent": "^5.1.2", "merge2": "^1.3.0", "micromatch": "^4.0.8" } }, "sha512-7MptL8U0cqcFdzIzwOTHoilX9x5BrNqye7Z/LuC7kCMRio1EMSyqRK3BEAUD7sXRq4iT4AzTVuZdhgQ2TCvYLg=="], | ||||
|  | ||||
|     "fast-json-stable-stringify": ["fast-json-stable-stringify@2.1.0", "", {}, "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw=="], | ||||
|  | ||||
|     "fast-levenshtein": ["fast-levenshtein@2.0.6", "", {}, "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw=="], | ||||
|  | ||||
|     "fastq": ["fastq@1.19.1", "", { "dependencies": { "reusify": "^1.0.4" } }, "sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ=="], | ||||
|  | ||||
|     "fdir": ["fdir@6.4.6", "", { "peerDependencies": { "picomatch": "^3 || ^4" }, "optionalPeers": ["picomatch"] }, "sha512-hiFoqpyZcfNm1yc4u8oWCf9A2c4D3QjCrks3zmoVKVxpQRzmPNar1hUJcBG2RQHvEVGDN+Jm81ZheVLAQMK6+w=="], | ||||
|  | ||||
|     "file-entry-cache": ["file-entry-cache@8.0.0", "", { "dependencies": { "flat-cache": "^4.0.0" } }, "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ=="], | ||||
|  | ||||
|     "fill-range": ["fill-range@7.1.1", "", { "dependencies": { "to-regex-range": "^5.0.1" } }, "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg=="], | ||||
|  | ||||
|     "find-up": ["find-up@5.0.0", "", { "dependencies": { "locate-path": "^6.0.0", "path-exists": "^4.0.0" } }, "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng=="], | ||||
|  | ||||
|     "flat-cache": ["flat-cache@4.0.1", "", { "dependencies": { "flatted": "^3.2.9", "keyv": "^4.5.4" } }, "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw=="], | ||||
|  | ||||
|     "flatted": ["flatted@3.3.3", "", {}, "sha512-GX+ysw4PBCz0PzosHDepZGANEuFCMLrnRTiEy9McGjmkCQYwRq4A/X786G/fjM/+OjsWSU1ZrY5qyARZmO/uwg=="], | ||||
|  | ||||
|     "foreground-child": ["foreground-child@3.3.1", "", { "dependencies": { "cross-spawn": "^7.0.6", "signal-exit": "^4.0.1" } }, "sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw=="], | ||||
|  | ||||
|     "fraction.js": ["fraction.js@4.3.7", "", {}, "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew=="], | ||||
| @@ -358,14 +466,24 @@ | ||||
|  | ||||
|     "glob-parent": ["glob-parent@6.0.2", "", { "dependencies": { "is-glob": "^4.0.3" } }, "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A=="], | ||||
|  | ||||
|     "globals": ["globals@16.3.0", "", {}, "sha512-bqWEnJ1Nt3neqx2q5SFfGS8r/ahumIakg3HcwtNlrVlwXIeNumWn/c7Pn/wKzGhf6SaW6H6uWXLqC30STCMchQ=="], | ||||
|  | ||||
|     "graphemer": ["graphemer@1.4.0", "", {}, "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag=="], | ||||
|  | ||||
|     "has-flag": ["has-flag@4.0.0", "", {}, "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ=="], | ||||
|  | ||||
|     "hasown": ["hasown@2.0.2", "", { "dependencies": { "function-bind": "^1.1.2" } }, "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ=="], | ||||
|  | ||||
|     "ieee754": ["ieee754@1.2.1", "", {}, "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA=="], | ||||
|  | ||||
|     "ignore": ["ignore@5.3.2", "", {}, "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g=="], | ||||
|  | ||||
|     "immutable": ["immutable@5.1.3", "", {}, "sha512-+chQdDfvscSF1SJqv2gn4SRO2ZyS3xL3r7IW/wWEEzrzLisnOlKiQu5ytC/BVNcS15C39WT2Hg/bjKjDMcu+zg=="], | ||||
|  | ||||
|     "import-fresh": ["import-fresh@3.3.1", "", { "dependencies": { "parent-module": "^1.0.0", "resolve-from": "^4.0.0" } }, "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ=="], | ||||
|  | ||||
|     "imurmurhash": ["imurmurhash@0.1.4", "", {}, "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA=="], | ||||
|  | ||||
|     "inline-style-parser": ["inline-style-parser@0.2.4", "", {}, "sha512-0aO8FkhNZlj/ZIbNi7Lxxr12obT7cL1moPfE4tg1LkX7LlLfC6DeX4l2ZEud1ukP9jNQyNnfzQVqwbwmAATY4Q=="], | ||||
|  | ||||
|     "is-binary-path": ["is-binary-path@2.1.0", "", { "dependencies": { "binary-extensions": "^2.0.0" } }, "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw=="], | ||||
| @@ -386,16 +504,34 @@ | ||||
|  | ||||
|     "jackspeak": ["jackspeak@3.4.3", "", { "dependencies": { "@isaacs/cliui": "^8.0.2" }, "optionalDependencies": { "@pkgjs/parseargs": "^0.11.0" } }, "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw=="], | ||||
|  | ||||
|     "jinx-rust": ["jinx-rust@0.1.6", "", {}, "sha512-qP+wtQL1PrDDFwtPKhNGtjWOmijCrKdfUHWTV2G/ikxfjrh+cjdvkQTmny9RAsVF0jiui9m+F0INWu4cuRcZeQ=="], | ||||
|  | ||||
|     "jiti": ["jiti@1.21.7", "", { "bin": { "jiti": "bin/jiti.js" } }, "sha512-/imKNG4EbWNrVjoNC/1H5/9GFy+tqjGBHCaSsN+P2RnPqjsLmv6UD3Ej+Kj8nBWaRAwyk7kK5ZUc+OEatnTR3A=="], | ||||
|  | ||||
|     "js-yaml": ["js-yaml@4.1.0", "", { "dependencies": { "argparse": "^2.0.1" }, "bin": { "js-yaml": "bin/js-yaml.js" } }, "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA=="], | ||||
|  | ||||
|     "json-buffer": ["json-buffer@3.0.1", "", {}, "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ=="], | ||||
|  | ||||
|     "json-schema-traverse": ["json-schema-traverse@0.4.1", "", {}, "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg=="], | ||||
|  | ||||
|     "json-stable-stringify-without-jsonify": ["json-stable-stringify-without-jsonify@1.0.1", "", {}, "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw=="], | ||||
|  | ||||
|     "keyv": ["keyv@4.5.4", "", { "dependencies": { "json-buffer": "3.0.1" } }, "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw=="], | ||||
|  | ||||
|     "kleur": ["kleur@4.1.5", "", {}, "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ=="], | ||||
|  | ||||
|     "known-css-properties": ["known-css-properties@0.37.0", "", {}, "sha512-JCDrsP4Z1Sb9JwG0aJ8Eo2r7k4Ou5MwmThS/6lcIe1ICyb7UBJKGRIUUdqc2ASdE/42lgz6zFUnzAIhtXnBVrQ=="], | ||||
|  | ||||
|     "levn": ["levn@0.4.1", "", { "dependencies": { "prelude-ls": "^1.2.1", "type-check": "~0.4.0" } }, "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ=="], | ||||
|  | ||||
|     "lilconfig": ["lilconfig@3.1.3", "", {}, "sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw=="], | ||||
|  | ||||
|     "lines-and-columns": ["lines-and-columns@1.2.4", "", {}, "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg=="], | ||||
|  | ||||
|     "locate-character": ["locate-character@3.0.0", "", {}, "sha512-SW13ws7BjaeJ6p7Q6CO2nchbYEc3X3J6WrmTTDto7yMPqVSZTUyY5Tjbid+Ab8gLnATtygYtiDIJGQRRn2ZOiA=="], | ||||
|  | ||||
|     "locate-path": ["locate-path@6.0.0", "", { "dependencies": { "p-locate": "^5.0.0" } }, "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw=="], | ||||
|  | ||||
|     "lodash.castarray": ["lodash.castarray@4.4.0", "", {}, "sha512-aVx8ztPv7/2ULbArGJ2Y42bG1mEQ5mGjpdvrbJcJFU3TbYybe+QlLS4pst9zV52ymy2in1KpFPiZnAOATxD4+Q=="], | ||||
|  | ||||
|     "lodash.isplainobject": ["lodash.isplainobject@4.0.6", "", {}, "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA=="], | ||||
| @@ -414,7 +550,7 @@ | ||||
|  | ||||
|     "micromatch": ["micromatch@4.0.8", "", { "dependencies": { "braces": "^3.0.3", "picomatch": "^2.3.1" } }, "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA=="], | ||||
|  | ||||
|     "minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], | ||||
|     "minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], | ||||
|  | ||||
|     "minipass": ["minipass@7.1.2", "", {}, "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw=="], | ||||
|  | ||||
| @@ -430,6 +566,8 @@ | ||||
|  | ||||
|     "nanoid": ["nanoid@3.3.11", "", { "bin": { "nanoid": "bin/nanoid.cjs" } }, "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w=="], | ||||
|  | ||||
|     "natural-compare": ["natural-compare@1.4.0", "", {}, "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw=="], | ||||
|  | ||||
|     "node-releases": ["node-releases@2.0.19", "", {}, "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw=="], | ||||
|  | ||||
|     "normalize-path": ["normalize-path@3.0.0", "", {}, "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA=="], | ||||
| @@ -442,12 +580,22 @@ | ||||
|  | ||||
|     "object-hash": ["object-hash@3.0.0", "", {}, "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw=="], | ||||
|  | ||||
|     "optionator": ["optionator@0.9.4", "", { "dependencies": { "deep-is": "^0.1.3", "fast-levenshtein": "^2.0.6", "levn": "^0.4.1", "prelude-ls": "^1.2.1", "type-check": "^0.4.0", "word-wrap": "^1.2.5" } }, "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g=="], | ||||
|  | ||||
|     "osu-classes": ["osu-classes@3.1.0", "", {}, "sha512-kz38FWMGnz5lr6ofovUrNaDAcs1gNpwlDc1qHjW86ILQZXG44w/+NflV7EyFomkI05XCADGfltE4FVoPwrkrmg=="], | ||||
|  | ||||
|     "osu-parsers": ["osu-parsers@4.1.7", "", { "dependencies": { "lzma-js-simple-v2": "^1.2.3" }, "peerDependencies": { "osu-classes": "^3.1.0" } }, "sha512-b8aYJy9vK0Yk8zVbxVN+HSChGnXufSxePb3gABG8s5YGCY+31CKJTUHDAVRST0kX4lyeI4Z3iRxsCRftHFHEug=="], | ||||
|  | ||||
|     "p-limit": ["p-limit@3.1.0", "", { "dependencies": { "yocto-queue": "^0.1.0" } }, "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ=="], | ||||
|  | ||||
|     "p-locate": ["p-locate@5.0.0", "", { "dependencies": { "p-limit": "^3.0.2" } }, "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw=="], | ||||
|  | ||||
|     "package-json-from-dist": ["package-json-from-dist@1.0.1", "", {}, "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw=="], | ||||
|  | ||||
|     "parent-module": ["parent-module@1.0.1", "", { "dependencies": { "callsites": "^3.0.0" } }, "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g=="], | ||||
|  | ||||
|     "path-exists": ["path-exists@4.0.0", "", {}, "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w=="], | ||||
|  | ||||
|     "path-key": ["path-key@3.1.1", "", {}, "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q=="], | ||||
|  | ||||
|     "path-parse": ["path-parse@1.0.7", "", {}, "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw=="], | ||||
| @@ -468,18 +616,28 @@ | ||||
|  | ||||
|     "postcss-js": ["postcss-js@4.0.1", "", { "dependencies": { "camelcase-css": "^2.0.1" }, "peerDependencies": { "postcss": "^8.4.21" } }, "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw=="], | ||||
|  | ||||
|     "postcss-load-config": ["postcss-load-config@4.0.2", "", { "dependencies": { "lilconfig": "^3.0.0", "yaml": "^2.3.4" }, "peerDependencies": { "postcss": ">=8.0.9", "ts-node": ">=9.0.0" }, "optionalPeers": ["postcss", "ts-node"] }, "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ=="], | ||||
|     "postcss-load-config": ["postcss-load-config@3.1.4", "", { "dependencies": { "lilconfig": "^2.0.5", "yaml": "^1.10.2" }, "peerDependencies": { "postcss": ">=8.0.9", "ts-node": ">=9.0.0" }, "optionalPeers": ["postcss", "ts-node"] }, "sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg=="], | ||||
|  | ||||
|     "postcss-nested": ["postcss-nested@6.2.0", "", { "dependencies": { "postcss-selector-parser": "^6.1.1" }, "peerDependencies": { "postcss": "^8.2.14" } }, "sha512-HQbt28KulC5AJzG+cZtj9kvKB93CFCdLvog1WFLf1D+xmMvPGlBstkpTEZfK5+AN9hfJocyBFCNiqyS48bpgzQ=="], | ||||
|  | ||||
|     "postcss-safe-parser": ["postcss-safe-parser@7.0.1", "", { "peerDependencies": { "postcss": "^8.4.31" } }, "sha512-0AioNCJZ2DPYz5ABT6bddIqlhgwhpHZ/l65YAYo0BCIn0xiDpsnTHz0gnoTGk0OXZW0JRs+cDwL8u/teRdz+8A=="], | ||||
|  | ||||
|     "postcss-scss": ["postcss-scss@4.0.9", "", { "peerDependencies": { "postcss": "^8.4.29" } }, "sha512-AjKOeiwAitL/MXxQW2DliT28EKukvvbEWx3LBmJIRN8KfBGZbRTxNYW0kSqi1COiTZ57nZ9NW06S6ux//N1c9A=="], | ||||
|  | ||||
|     "postcss-selector-parser": ["postcss-selector-parser@6.1.2", "", { "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" } }, "sha512-Q8qQfPiZ+THO/3ZrOrO0cJJKfpYCagtMUkXbnEfmgUjwXg6z/WBeOyS9APBBPCTSiDV+s4SwQGu8yFsiMRIudg=="], | ||||
|  | ||||
|     "postcss-value-parser": ["postcss-value-parser@4.2.0", "", {}, "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ=="], | ||||
|  | ||||
|     "prelude-ls": ["prelude-ls@1.2.1", "", {}, "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g=="], | ||||
|  | ||||
|     "prettier": ["prettier@3.6.1", "", { "bin": { "prettier": "bin/prettier.cjs" } }, "sha512-5xGWRa90Sp2+x1dQtNpIpeOQpTDBs9cZDmA/qs2vDNN2i18PdapqY7CmBeyLlMuGqXJRIOPaCaVZTLNQRWUH/A=="], | ||||
|  | ||||
|     "prettier-plugin-rust": ["prettier-plugin-rust@0.1.9", "", { "dependencies": { "jinx-rust": "0.1.6", "prettier": "^2.7.1" } }, "sha512-n1DTTJQaHMdnoG/+nKUvBm3EKsMVWsYES2UPCiOPiZdBrmuAO/pX++m7L3+Hz3uuhtddpH0HRKHB2F3jbtJBOQ=="], | ||||
|  | ||||
|     "prettier-plugin-svelte": ["prettier-plugin-svelte@3.4.0", "", { "peerDependencies": { "prettier": "^3.0.0", "svelte": "^3.2.0 || ^4.0.0-next.0 || ^5.0.0-next.0" } }, "sha512-pn1ra/0mPObzqoIQn/vUTR3ZZI6UuZ0sHqMK5x2jMLGrs53h0sXhkVuDcrlssHwIMk7FYrMjHBPoUSyyEEDlBQ=="], | ||||
|  | ||||
|     "punycode": ["punycode@2.3.1", "", {}, "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg=="], | ||||
|  | ||||
|     "queue-microtask": ["queue-microtask@1.2.3", "", {}, "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A=="], | ||||
|  | ||||
|     "radix-icons-svelte": ["radix-icons-svelte@1.2.1", "", {}, "sha512-svmiMd0ocpdTm9cvAz0klcZpnh639lVctj6psQiawd4pYalVzOG4cX+JizAgRckyTAsRVdzObP7D2EBrSfdghA=="], | ||||
| @@ -490,6 +648,8 @@ | ||||
|  | ||||
|     "resolve": ["resolve@1.22.10", "", { "dependencies": { "is-core-module": "^2.16.0", "path-parse": "^1.0.7", "supports-preserve-symlinks-flag": "^1.0.0" }, "bin": { "resolve": "bin/resolve" } }, "sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w=="], | ||||
|  | ||||
|     "resolve-from": ["resolve-from@4.0.0", "", {}, "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g=="], | ||||
|  | ||||
|     "reusify": ["reusify@1.1.0", "", {}, "sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw=="], | ||||
|  | ||||
|     "rollup": ["rollup@4.44.1", "", { "dependencies": { "@types/estree": "1.0.8" }, "optionalDependencies": { "@rollup/rollup-android-arm-eabi": "4.44.1", "@rollup/rollup-android-arm64": "4.44.1", "@rollup/rollup-darwin-arm64": "4.44.1", "@rollup/rollup-darwin-x64": "4.44.1", "@rollup/rollup-freebsd-arm64": "4.44.1", "@rollup/rollup-freebsd-x64": "4.44.1", "@rollup/rollup-linux-arm-gnueabihf": "4.44.1", "@rollup/rollup-linux-arm-musleabihf": "4.44.1", "@rollup/rollup-linux-arm64-gnu": "4.44.1", "@rollup/rollup-linux-arm64-musl": "4.44.1", "@rollup/rollup-linux-loongarch64-gnu": "4.44.1", "@rollup/rollup-linux-powerpc64le-gnu": "4.44.1", "@rollup/rollup-linux-riscv64-gnu": "4.44.1", "@rollup/rollup-linux-riscv64-musl": "4.44.1", "@rollup/rollup-linux-s390x-gnu": "4.44.1", "@rollup/rollup-linux-x64-gnu": "4.44.1", "@rollup/rollup-linux-x64-musl": "4.44.1", "@rollup/rollup-win32-arm64-msvc": "4.44.1", "@rollup/rollup-win32-ia32-msvc": "4.44.1", "@rollup/rollup-win32-x64-msvc": "4.44.1", "fsevents": "~2.3.2" }, "bin": { "rollup": "dist/bin/rollup" } }, "sha512-x8H8aPvD+xbl0Do8oez5f5o8eMS3trfCghc4HhLAnCkj7Vl0d1JWGs0UF/D886zLW2rOj2QymV/JcSSsw+XDNg=="], | ||||
| @@ -536,6 +696,8 @@ | ||||
|  | ||||
|     "sass-embedded-win32-x64": ["sass-embedded-win32-x64@1.89.2", "", { "os": "win32", "cpu": "x64" }, "sha512-cS2j5ljdkQsb4PaORiClaVYynE9OAPZG/XjbOMxpQmjRIf7UroY4PEIH+Waf+y47PfXFX9SyxhYuw2NIKGbEng=="], | ||||
|  | ||||
|     "semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], | ||||
|  | ||||
|     "set-cookie-parser": ["set-cookie-parser@2.7.1", "", {}, "sha512-IOc8uWeOZgnb3ptbCURJWNjWUPcO3ZnTTdzsurqERrP6nPyv+paC55vJM0LpOlT2ne+Ix+9+CRG1MNLlyZ4GjQ=="], | ||||
|  | ||||
|     "shebang-command": ["shebang-command@2.0.0", "", { "dependencies": { "shebang-regex": "^3.0.0" } }, "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA=="], | ||||
| @@ -556,6 +718,8 @@ | ||||
|  | ||||
|     "strip-ansi-cjs": ["strip-ansi@6.0.1", "", { "dependencies": { "ansi-regex": "^5.0.1" } }, "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A=="], | ||||
|  | ||||
|     "strip-json-comments": ["strip-json-comments@3.1.1", "", {}, "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig=="], | ||||
|  | ||||
|     "style-to-object": ["style-to-object@1.0.9", "", { "dependencies": { "inline-style-parser": "0.2.4" } }, "sha512-G4qppLgKu/k6FwRpHiGiKPaPTFcG3g4wNVX/Qsfu+RqQM30E7Tyu/TEgxcL9PNLF5pdRLwQdE3YKKf+KF2Dzlw=="], | ||||
|  | ||||
|     "sucrase": ["sucrase@3.35.0", "", { "dependencies": { "@jridgewell/gen-mapping": "^0.3.2", "commander": "^4.0.0", "glob": "^10.3.10", "lines-and-columns": "^1.1.6", "mz": "^2.7.0", "pirates": "^4.0.1", "ts-interface-checker": "^0.1.9" }, "bin": { "sucrase": "bin/sucrase", "sucrase-node": "bin/sucrase-node" } }, "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA=="], | ||||
| @@ -570,6 +734,8 @@ | ||||
|  | ||||
|     "svelte-confetti": ["svelte-confetti@2.3.1", "", { "peerDependencies": { "svelte": ">=5.0.0" } }, "sha512-bKd8etTOeBQyeS9LDPuSd7Oqy5msf0xvxItzsHPajKaarr/LWFzqPq7rp6QQO5rGTzLgM0fmjovOvLkRbrd2gg=="], | ||||
|  | ||||
|     "svelte-eslint-parser": ["svelte-eslint-parser@1.2.0", "", { "dependencies": { "eslint-scope": "^8.2.0", "eslint-visitor-keys": "^4.0.0", "espree": "^10.0.0", "postcss": "^8.4.49", "postcss-scss": "^4.0.9", "postcss-selector-parser": "^7.0.0" }, "peerDependencies": { "svelte": "^3.37.0 || ^4.0.0 || ^5.0.0" }, "optionalPeers": ["svelte"] }, "sha512-mbPtajIeuiyU80BEyGvwAktBeTX7KCr5/0l+uRGLq1dafwRNrjfM5kHGJScEBlPG3ipu6dJqfW/k0/fujvIEVw=="], | ||||
|  | ||||
|     "svelte-sonner": ["svelte-sonner@0.3.28", "", { "peerDependencies": { "svelte": "^3.0.0 || ^4.0.0 || ^5.0.0-next.1" } }, "sha512-K3AmlySeFifF/cKgsYNv5uXqMVNln0NBAacOYgmkQStLa/UoU0LhfAACU6Gr+YYC8bOCHdVmFNoKuDbMEsppJg=="], | ||||
|  | ||||
|     "svelte-toolbelt": ["svelte-toolbelt@0.7.1", "", { "dependencies": { "clsx": "^2.1.1", "runed": "^0.23.2", "style-to-object": "^1.0.8" }, "peerDependencies": { "svelte": "^5.0.0" } }, "sha512-HcBOcR17Vx9bjaOceUvxkY3nGmbBmCBBbuWLLEWO6jtmWH8f/QoWmbyUfQZrpDINH39en1b8mptfPQT9VKQ1xQ=="], | ||||
| @@ -598,16 +764,24 @@ | ||||
|  | ||||
|     "totalist": ["totalist@3.0.1", "", {}, "sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ=="], | ||||
|  | ||||
|     "ts-api-utils": ["ts-api-utils@2.1.0", "", { "peerDependencies": { "typescript": ">=4.8.4" } }, "sha512-CUgTZL1irw8u29bzrOD/nH85jqyc74D6SshFgujOIA7osm2Rz7dYH77agkx7H4FBNxDq7Cjf+IjaX/8zwFW+ZQ=="], | ||||
|  | ||||
|     "ts-interface-checker": ["ts-interface-checker@0.1.13", "", {}, "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA=="], | ||||
|  | ||||
|     "tslib": ["tslib@2.8.1", "", {}, "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w=="], | ||||
|  | ||||
|     "type-check": ["type-check@0.4.0", "", { "dependencies": { "prelude-ls": "^1.2.1" } }, "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew=="], | ||||
|  | ||||
|     "typescript": ["typescript@5.8.3", "", { "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" } }, "sha512-p1diW6TqL9L07nNxvRMM7hMMw4c5XOo/1ibL4aAIGmSAt9slTE1Xgw5KWuof2uTOvCg9BY7ZRi+GaF+7sfgPeQ=="], | ||||
|  | ||||
|     "typescript-eslint": ["typescript-eslint@8.35.1", "", { "dependencies": { "@typescript-eslint/eslint-plugin": "8.35.1", "@typescript-eslint/parser": "8.35.1", "@typescript-eslint/utils": "8.35.1" }, "peerDependencies": { "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <5.9.0" } }, "sha512-xslJjFzhOmHYQzSB/QTeASAHbjmxOGEP6Coh93TXmUBFQoJ1VU35UHIDmG06Jd6taf3wqqC1ntBnCMeymy5Ovw=="], | ||||
|  | ||||
|     "undici-types": ["undici-types@6.21.0", "", {}, "sha512-iwDZqg0QAGrg9Rav5H4n0M64c3mkR59cJ6wQp+7C4nI0gsmExaedaYLNO44eT4AtBBwjbTiGPMlt2Md0T9H9JQ=="], | ||||
|  | ||||
|     "update-browserslist-db": ["update-browserslist-db@1.1.3", "", { "dependencies": { "escalade": "^3.2.0", "picocolors": "^1.1.1" }, "peerDependencies": { "browserslist": ">= 4.21.0" }, "bin": { "update-browserslist-db": "cli.js" } }, "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw=="], | ||||
|  | ||||
|     "uri-js": ["uri-js@4.4.1", "", { "dependencies": { "punycode": "^2.1.0" } }, "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg=="], | ||||
|  | ||||
|     "util-deprecate": ["util-deprecate@1.0.2", "", {}, "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="], | ||||
|  | ||||
|     "uuid": ["uuid@11.1.0", "", { "bin": { "uuid": "dist/esm/bin/uuid" } }, "sha512-0/A9rDy9P7cJ+8w1c9WD9V//9Wj15Ce2MPz8Ri6032usz+NfePxx5AcN3bN+r6ZL6jEo066/yNYB3tn4pQEx+A=="], | ||||
| @@ -622,40 +796,74 @@ | ||||
|  | ||||
|     "which": ["which@2.0.2", "", { "dependencies": { "isexe": "^2.0.0" }, "bin": { "node-which": "./bin/node-which" } }, "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA=="], | ||||
|  | ||||
|     "word-wrap": ["word-wrap@1.2.5", "", {}, "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA=="], | ||||
|  | ||||
|     "wrap-ansi": ["wrap-ansi@8.1.0", "", { "dependencies": { "ansi-styles": "^6.1.0", "string-width": "^5.0.1", "strip-ansi": "^7.0.1" } }, "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ=="], | ||||
|  | ||||
|     "wrap-ansi-cjs": ["wrap-ansi@7.0.0", "", { "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", "strip-ansi": "^6.0.0" } }, "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q=="], | ||||
|  | ||||
|     "yaml": ["yaml@2.8.0", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-4lLa/EcQCB0cJkyts+FpIRx5G/llPxfP6VQU5KByHEhLxY3IJCH0f0Hy1MHI8sClTvsIb8qwRJ6R/ZdlDJ/leQ=="], | ||||
|  | ||||
|     "yocto-queue": ["yocto-queue@0.1.0", "", {}, "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q=="], | ||||
|  | ||||
|     "zimmerframe": ["zimmerframe@1.1.2", "", {}, "sha512-rAbqEGa8ovJy4pyBxZM70hg4pE6gDgaQ0Sl9M3enG3I0d6H4XSAM3GeNGLKnsBpuijUow064sf7ww1nutC5/3w=="], | ||||
|  | ||||
|     "@eslint-community/eslint-utils/eslint-visitor-keys": ["eslint-visitor-keys@3.4.3", "", {}, "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag=="], | ||||
|  | ||||
|     "@eslint/eslintrc/globals": ["globals@14.0.0", "", {}, "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ=="], | ||||
|  | ||||
|     "@eslint/plugin-kit/@eslint/core": ["@eslint/core@0.15.1", "", { "dependencies": { "@types/json-schema": "^7.0.15" } }, "sha512-bkOp+iumZCCbt1K1CmWf0R9pM5yKpDv+ZXtvSyQpudrI9kuFLp+bM2WOPXImuD/ceQuaa8f5pj93Y7zyECIGNA=="], | ||||
|  | ||||
|     "@humanfs/node/@humanwhocodes/retry": ["@humanwhocodes/retry@0.3.1", "", {}, "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA=="], | ||||
|  | ||||
|     "@tailwindcss/typography/postcss-selector-parser": ["postcss-selector-parser@6.0.10", "", { "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" } }, "sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w=="], | ||||
|  | ||||
|     "@typescript-eslint/eslint-plugin/ignore": ["ignore@7.0.5", "", {}, "sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg=="], | ||||
|  | ||||
|     "@typescript-eslint/typescript-estree/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], | ||||
|  | ||||
|     "anymatch/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], | ||||
|  | ||||
|     "chalk/supports-color": ["supports-color@7.2.0", "", { "dependencies": { "has-flag": "^4.0.0" } }, "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw=="], | ||||
|  | ||||
|     "fast-glob/glob-parent": ["glob-parent@5.1.2", "", { "dependencies": { "is-glob": "^4.0.1" } }, "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow=="], | ||||
|  | ||||
|     "glob/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], | ||||
|  | ||||
|     "micromatch/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], | ||||
|  | ||||
|     "mode-watcher/runed": ["runed@0.25.0", "", { "dependencies": { "esm-env": "^1.0.0" }, "peerDependencies": { "svelte": "^5.7.0" } }, "sha512-7+ma4AG9FT2sWQEA0Egf6mb7PBT2vHyuHail1ie8ropfSjvZGtEAx8YTmUjv/APCsdRRxEVvArNjALk9zFSOrg=="], | ||||
|  | ||||
|     "postcss-load-config/lilconfig": ["lilconfig@2.1.0", "", {}, "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ=="], | ||||
|  | ||||
|     "postcss-load-config/yaml": ["yaml@1.10.2", "", {}, "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg=="], | ||||
|  | ||||
|     "prettier-plugin-rust/prettier": ["prettier@2.8.8", "", { "bin": { "prettier": "bin-prettier.js" } }, "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q=="], | ||||
|  | ||||
|     "string-width-cjs/emoji-regex": ["emoji-regex@8.0.0", "", {}, "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A=="], | ||||
|  | ||||
|     "string-width-cjs/strip-ansi": ["strip-ansi@6.0.1", "", { "dependencies": { "ansi-regex": "^5.0.1" } }, "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A=="], | ||||
|  | ||||
|     "strip-ansi-cjs/ansi-regex": ["ansi-regex@5.0.1", "", {}, "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ=="], | ||||
|  | ||||
|     "svelte-eslint-parser/postcss-selector-parser": ["postcss-selector-parser@7.1.0", "", { "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" } }, "sha512-8sLjZwK0R+JlxlYcTuVnyT2v+htpdrjDOKuMcOVdYjt52Lh8hWRYpxBPoKx/Zg+bcjc3wx6fmQevMmUztS/ccA=="], | ||||
|  | ||||
|     "tailwind-variants/tailwind-merge": ["tailwind-merge@2.5.4", "", {}, "sha512-0q8cfZHMu9nuYP/b5Shb7Y7Sh1B7Nnl5GqNr1U+n2p6+mybvRtayrQ+0042Z5byvTA8ihjlP8Odo8/VnHbZu4Q=="], | ||||
|  | ||||
|     "tailwindcss/chokidar": ["chokidar@3.6.0", "", { "dependencies": { "anymatch": "~3.1.2", "braces": "~3.0.2", "glob-parent": "~5.1.2", "is-binary-path": "~2.1.0", "is-glob": "~4.0.1", "normalize-path": "~3.0.0", "readdirp": "~3.6.0" }, "optionalDependencies": { "fsevents": "~2.3.2" } }, "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw=="], | ||||
|  | ||||
|     "wrap-ansi-cjs/ansi-styles": ["ansi-styles@4.3.0", "", { "dependencies": { "color-convert": "^2.0.1" } }, "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg=="], | ||||
|     "tailwindcss/postcss-load-config": ["postcss-load-config@4.0.2", "", { "dependencies": { "lilconfig": "^3.0.0", "yaml": "^2.3.4" }, "peerDependencies": { "postcss": ">=8.0.9", "ts-node": ">=9.0.0" }, "optionalPeers": ["postcss", "ts-node"] }, "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ=="], | ||||
|  | ||||
|     "wrap-ansi/ansi-styles": ["ansi-styles@6.2.1", "", {}, "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug=="], | ||||
|  | ||||
|     "wrap-ansi-cjs/string-width": ["string-width@4.2.3", "", { "dependencies": { "emoji-regex": "^8.0.0", "is-fullwidth-code-point": "^3.0.0", "strip-ansi": "^6.0.1" } }, "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g=="], | ||||
|  | ||||
|     "wrap-ansi-cjs/strip-ansi": ["strip-ansi@6.0.1", "", { "dependencies": { "ansi-regex": "^5.0.1" } }, "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A=="], | ||||
|  | ||||
|     "@typescript-eslint/typescript-estree/minimatch/brace-expansion": ["brace-expansion@2.0.2", "", { "dependencies": { "balanced-match": "^1.0.0" } }, "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ=="], | ||||
|  | ||||
|     "glob/minimatch/brace-expansion": ["brace-expansion@2.0.2", "", { "dependencies": { "balanced-match": "^1.0.0" } }, "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ=="], | ||||
|  | ||||
|     "string-width-cjs/strip-ansi/ansi-regex": ["ansi-regex@5.0.1", "", {}, "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ=="], | ||||
|  | ||||
|     "tailwindcss/chokidar/glob-parent": ["glob-parent@5.1.2", "", { "dependencies": { "is-glob": "^4.0.1" } }, "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow=="], | ||||
|   | ||||
							
								
								
									
										40
									
								
								eslint.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								eslint.config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| import prettier from 'eslint-config-prettier'; | ||||
| import { includeIgnoreFile } from '@eslint/compat'; | ||||
| import js from '@eslint/js'; | ||||
| import svelte from 'eslint-plugin-svelte'; | ||||
| import globals from 'globals'; | ||||
| import { fileURLToPath } from 'node:url'; | ||||
| import ts from 'typescript-eslint'; | ||||
| import svelteConfig from './svelte.config.js'; | ||||
|  | ||||
| const gitignorePath = fileURLToPath(new URL('./.gitignore', import.meta.url)); | ||||
|  | ||||
| export default ts.config( | ||||
|   includeIgnoreFile(gitignorePath), | ||||
|   js.configs.recommended, | ||||
|   ...ts.configs.recommended, | ||||
|   ...svelte.configs.recommended, | ||||
|   prettier, | ||||
|   ...svelte.configs.prettier, | ||||
|   { | ||||
|     languageOptions: { | ||||
|       globals: { ...globals.browser, ...globals.node }, | ||||
|     }, | ||||
|     rules: { | ||||
|       // typescript-eslint strongly recommend that you do not use the no-undef lint rule on TypeScript projects. | ||||
|       // see: https://typescript-eslint.io/troubleshooting/faqs/eslint/#i-get-errors-from-the-no-undef-rule-about-global-variables-not-being-defined-even-though-there-are-no-typescript-errors | ||||
|       'no-undef': 'off', | ||||
|     }, | ||||
|   }, | ||||
|   { | ||||
|     files: ['**/*.svelte', '**/*.svelte.ts', '**/*.svelte.js'], | ||||
|     languageOptions: { | ||||
|       parserOptions: { | ||||
|         projectService: true, | ||||
|         extraFileExtensions: ['.svelte'], | ||||
|         parser: ts.parser, | ||||
|         svelteConfig, | ||||
|       }, | ||||
|     }, | ||||
|   } | ||||
| ); | ||||
							
								
								
									
										16
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								package.json
									
									
									
									
									
								
							| @@ -12,7 +12,9 @@ | ||||
|     "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", | ||||
|     "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch", | ||||
|     "tauri": "tauri", | ||||
|     "update-logo": "bun run tauri icon ./static/logo.png" | ||||
|     "update-logo": "bun run tauri icon ./static/logo.png", | ||||
|     "format": "prettier --write .", | ||||
|     "lint": "prettier --check . && eslint ." | ||||
|   }, | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
| @@ -34,10 +36,13 @@ | ||||
|     "lucide-svelte": "0.523.0", | ||||
|     "osu-classes": "3.1.0", | ||||
|     "osu-parsers": "4.1.7", | ||||
|     "prettier-plugin-rust": "^0.1.9", | ||||
|     "radix-icons-svelte": "1.2.1", | ||||
|     "svelte-confetti": "^2.0.0" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@eslint/compat": "^1.2.5", | ||||
|     "@eslint/js": "^9.18.0", | ||||
|     "@lucide/svelte": "^0.482.0", | ||||
|     "@sveltejs/adapter-static": "3.0.8", | ||||
|     "@sveltejs/kit": "2.22.2", | ||||
| @@ -47,9 +52,13 @@ | ||||
|     "autoprefixer": "10.4.21", | ||||
|     "bits-ui": "^1.4.7", | ||||
|     "clsx": "2.1.1", | ||||
|     "eslint": "^9.18.0", | ||||
|     "eslint-config-prettier": "^10.0.1", | ||||
|     "eslint-plugin-svelte": "^3.0.0", | ||||
|     "globals": "^16.0.0", | ||||
|     "mode-watcher": "^1.0.6", | ||||
|     "prettier": "^3.6.1", | ||||
|     "prettier-plugin-svelte": "^3.4.0", | ||||
|     "prettier": "^3.4.2", | ||||
|     "prettier-plugin-svelte": "^3.3.3", | ||||
|     "sass-embedded": "1.89.2", | ||||
|     "svelte": "5.34.8", | ||||
|     "svelte-check": "4.2.2", | ||||
| @@ -60,6 +69,7 @@ | ||||
|     "tailwindcss-animate": "1.0.7", | ||||
|     "tslib": "2.8.1", | ||||
|     "typescript": "5.8.3", | ||||
|     "typescript-eslint": "^8.20.0", | ||||
|     "vite": "7.0.0", | ||||
|     "vite-plugin-devtools-json": "^0.2.0" | ||||
|   } | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| export default { | ||||
|   plugins: { | ||||
|     tailwindcss: {}, | ||||
|     autoprefixer: {} | ||||
|   } | ||||
|     autoprefixer: {}, | ||||
|   }, | ||||
| }; | ||||
|   | ||||
							
								
								
									
										12
									
								
								src-tauri/Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										12
									
								
								src-tauri/Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -468,9 +468,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "cc" | ||||
| version = "1.2.27" | ||||
| version = "1.2.28" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d487aa071b5f64da6f19a3e848e3578944b726ee5a4854b82172f02aa876bfdc" | ||||
| checksum = "4ad45f4f74e4e20eaa392913b7b33a7091c87e59628f4dd27888205ad888843c" | ||||
| dependencies = [ | ||||
|  "shlex", | ||||
| ] | ||||
| @@ -4071,9 +4071,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "shared_child" | ||||
| version = "1.1.0" | ||||
| version = "1.1.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "c2778001df1384cf20b6dc5a5a90f48da35539885edaaefd887f8d744e939c0b" | ||||
| checksum = "1e362d9935bc50f019969e2f9ecd66786612daae13e8f277be7bfb66e8bed3f7" | ||||
| dependencies = [ | ||||
|  "libc", | ||||
|  "sigchld", | ||||
| @@ -5105,9 +5105,9 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" | ||||
|  | ||||
| [[package]] | ||||
| name = "tokio" | ||||
| version = "1.46.0" | ||||
| version = "1.46.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "1140bb80481756a8cbe10541f37433b459c5aa1e727b4c020fbfebdc25bf3ec4" | ||||
| checksum = "0cc3a2344dafbe23a245241fe8b09735b521110d30fcefbbd5feb1797ca35d17" | ||||
| dependencies = [ | ||||
|  "backtrace", | ||||
|  "bytes", | ||||
|   | ||||
| @@ -27,16 +27,18 @@ tauri-plugin-sql = "2.3.0" | ||||
| tauri-plugin-dialog = "2.3.0" | ||||
| tauri-plugin-fs = "2.4.0" | ||||
| hardware-id = "0.3.0" | ||||
| winreg = "0.55.0" | ||||
| tauri-plugin-cors-fetch = "4.1.0" | ||||
| sysinfo = "0.35.2" | ||||
| winapi = { version = "0.3", features = ["winuser"] } | ||||
| reqwest = { version = "0.12.22", features = ["json", "stream"] } | ||||
| md5 = "0.8.0" | ||||
| tokio = { version = "1.46.0", features = ["full"] } | ||||
| tokio = { version = "1.46.1", features = ["full"] } | ||||
| open = "5.3.2" | ||||
| windows-sys = "0.60.2" | ||||
|  | ||||
| [target.'cfg(windows)'.dependencies] | ||||
| winreg = "0.55.0" | ||||
| winapi = { version = "0.3", features = ["winuser"] } | ||||
|  | ||||
| [target.'cfg(not(any(target_os = "android", target_os = "ios")))'.dependencies] | ||||
| tauri-plugin-single-instance = "2.3.0" | ||||
|  | ||||
|   | ||||
| @@ -2,9 +2,7 @@ | ||||
|   "$schema": "../gen/schemas/desktop-schema.json", | ||||
|   "identifier": "default", | ||||
|   "description": "Capability for the main window", | ||||
|   "windows": [ | ||||
|     "main" | ||||
|   ], | ||||
|   "windows": ["main"], | ||||
|   "permissions": [ | ||||
|     "core:default", | ||||
|     "shell:allow-open", | ||||
| @@ -19,59 +17,59 @@ | ||||
|     "core:window:allow-show", | ||||
|     "fs:default", | ||||
|     { | ||||
|       "identifier": "fs:allow-write", | ||||
|       "identifier": "fs:allow-read", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-read", | ||||
|       "identifier": "fs:allow-write", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-exists", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-write-file", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-read-file", | ||||
|       "allow": [ | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|       "identifier": "fs:allow-write-file", | ||||
|       "allow": [ | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-read-text-file", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "identifier": "fs:allow-mkdir", | ||||
|       "allow": [ | ||||
|         { | ||||
|           "path": "$HOME/**/*" | ||||
|         } | ||||
|         { "path": "$HOME/.ezpplauncher" }, | ||||
|         { "path": "$HOME/.ezpplauncher/*" }, | ||||
|         { "path": "$HOME/.ezpplauncher/**/*" } | ||||
|       ] | ||||
|     } | ||||
|   ] | ||||
|   | ||||
| @@ -63,8 +63,18 @@ pub fn valid_osu_folder(folder: String) -> bool { | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| #[cfg(not(windows))] | ||||
| #[tauri::command] | ||||
| pub fn find_osu_installation() -> Option<String> { | ||||
|     None | ||||
| } | ||||
|  | ||||
| #[cfg(windows)] | ||||
| #[tauri::command] | ||||
| pub fn find_osu_installation() -> Option<String> { | ||||
|     use winreg::RegKey; | ||||
|     use winreg::enums::*; | ||||
|  | ||||
|     let hklm_registry_paths = ["SOFTWARE\\Classes\\osu\\DefaultIcon"]; | ||||
|  | ||||
|     let hkcr_registry_paths = [ | ||||
| @@ -140,7 +150,7 @@ pub fn find_osu_installation() -> Option<String> { | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     return None; | ||||
|     None | ||||
| } | ||||
|  | ||||
| #[tauri::command] | ||||
|   | ||||
| @@ -1,6 +1,4 @@ | ||||
| use std::ffi::OsString; | ||||
| use std::fs; | ||||
| use std::os::windows::ffi::OsStringExt; | ||||
| use std::path::Path; | ||||
| use sysinfo::Pid; | ||||
|  | ||||
| @@ -178,12 +176,20 @@ pub fn get_osu_config<P: AsRef<Path>>( | ||||
|     return Some(config_map); | ||||
| } | ||||
|  | ||||
| #[cfg(not(windows))] | ||||
| pub fn get_window_title_by_pid(_pid: Pid) -> String { | ||||
|     "".to_string() | ||||
| } | ||||
|  | ||||
| #[cfg(windows)] | ||||
| pub fn get_window_title_by_pid(pid: Pid) -> String { | ||||
|     use std::sync::{Arc, Mutex}; | ||||
|     use winapi::shared::windef::HWND; | ||||
|     use winapi::um::winuser::{ | ||||
|         EnumWindows, GetWindowTextW, GetWindowThreadProcessId, IsWindowVisible, | ||||
|     }; | ||||
|     use std::ffi::OsString; | ||||
|     use std::os::windows::ffi::OsStringExt; | ||||
|  | ||||
|     extern "system" fn enum_windows_proc( | ||||
|         hwnd: HWND, | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| <!doctype html> | ||||
| <html lang="en" class="dark"> | ||||
|  | ||||
|   <head> | ||||
|     <meta charset="utf-8" /> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1" /> | ||||
| @@ -11,5 +10,4 @@ | ||||
|   <body class="bg-theme-950" data-sveltekit-preload-data="hover"> | ||||
|     <div style="display: contents">%sveltekit.body%</div> | ||||
|   </body> | ||||
|  | ||||
| </html> | ||||
| @@ -1,4 +1,4 @@ | ||||
| const API_ENDPOINT = "https://osu.direct/api/"; | ||||
| const API_ENDPOINT = 'https://osu.direct/api/'; | ||||
|  | ||||
| export const osudirect = { | ||||
|   osu: async (mapId: number): Promise<string | undefined> => { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| 	import { buttonVariants } from "$lib/components/ui/button/index.js"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
|   import { buttonVariants } from '$lib/components/ui/button/index.js'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| 	import { buttonVariants } from "$lib/components/ui/button/index.js"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
|   import { buttonVariants } from '$lib/components/ui/button/index.js'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,6 +12,6 @@ | ||||
|  | ||||
| <AlertDialogPrimitive.Cancel | ||||
|   bind:ref | ||||
| 	class={cn(buttonVariants({ variant: "outline" }), "mt-2 sm:mt-0", className)} | ||||
|   class={cn(buttonVariants({ variant: 'outline' }), 'mt-2 sm:mt-0', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive, type WithoutChild } from "bits-ui"; | ||||
| 	import AlertDialogOverlay from "./alert-dialog-overlay.svelte"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive, type WithoutChild } from 'bits-ui'; | ||||
|   import AlertDialogOverlay from './alert-dialog-overlay.svelte'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -18,7 +18,7 @@ | ||||
|   <AlertDialogPrimitive.Content | ||||
|     bind:ref | ||||
|     class={cn( | ||||
| 			"bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border p-6 shadow-lg duration-200 sm:rounded-lg", | ||||
|       'bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border p-6 shadow-lg duration-200 sm:rounded-lg', | ||||
|       className | ||||
|     )} | ||||
|     {...restProps} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <AlertDialogPrimitive.Description | ||||
|   bind:ref | ||||
| 	class={cn("text-muted-foreground text-sm", className)} | ||||
|   class={cn('text-muted-foreground text-sm', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import type { WithElementRef } from "bits-ui"; | ||||
| 	import type { HTMLAttributes } from "svelte/elements"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { WithElementRef } from 'bits-ui'; | ||||
|   import type { HTMLAttributes } from 'svelte/elements'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -13,7 +13,7 @@ | ||||
|  | ||||
| <div | ||||
|   bind:this={ref} | ||||
| 	class={cn("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2", className)} | ||||
|   class={cn('flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   {@render children?.()} | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import type { WithElementRef } from "bits-ui"; | ||||
| 	import type { HTMLAttributes } from "svelte/elements"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { WithElementRef } from 'bits-ui'; | ||||
|   import type { HTMLAttributes } from 'svelte/elements'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -13,7 +13,7 @@ | ||||
|  | ||||
| <div | ||||
|   bind:this={ref} | ||||
| 	class={cn("flex flex-col space-y-2 text-center sm:text-left", className)} | ||||
|   class={cn('flex flex-col space-y-2 text-center sm:text-left', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   {@render children?.()} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
| <AlertDialogPrimitive.Overlay | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0  fixed inset-0 z-50 bg-black/80", | ||||
|     'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0  fixed inset-0 z-50 bg-black/80', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
|  | ||||
| <AlertDialogPrimitive.Title | ||||
|   bind:ref | ||||
| 	class={cn("text-lg font-semibold", className)} | ||||
|   class={cn('text-lg font-semibold', className)} | ||||
|   {level} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| import { AlertDialog as AlertDialogPrimitive } from "bits-ui"; | ||||
| import Title from "./alert-dialog-title.svelte"; | ||||
| import Action from "./alert-dialog-action.svelte"; | ||||
| import Cancel from "./alert-dialog-cancel.svelte"; | ||||
| import Footer from "./alert-dialog-footer.svelte"; | ||||
| import Header from "./alert-dialog-header.svelte"; | ||||
| import Overlay from "./alert-dialog-overlay.svelte"; | ||||
| import Content from "./alert-dialog-content.svelte"; | ||||
| import Description from "./alert-dialog-description.svelte"; | ||||
| import { AlertDialog as AlertDialogPrimitive } from 'bits-ui'; | ||||
| import Title from './alert-dialog-title.svelte'; | ||||
| import Action from './alert-dialog-action.svelte'; | ||||
| import Cancel from './alert-dialog-cancel.svelte'; | ||||
| import Footer from './alert-dialog-footer.svelte'; | ||||
| import Header from './alert-dialog-header.svelte'; | ||||
| import Overlay from './alert-dialog-overlay.svelte'; | ||||
| import Content from './alert-dialog-content.svelte'; | ||||
| import Description from './alert-dialog-description.svelte'; | ||||
|  | ||||
| const Root = AlertDialogPrimitive.Root; | ||||
| const Trigger = AlertDialogPrimitive.Trigger; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Avatar as AvatarPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Avatar as AvatarPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <AvatarPrimitive.Fallback | ||||
|   bind:ref | ||||
| 	class={cn("bg-muted flex h-full w-full items-center justify-center rounded-full", className)} | ||||
|   class={cn('bg-muted flex h-full w-full items-center justify-center rounded-full', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Avatar as AvatarPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Avatar as AvatarPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <AvatarPrimitive.Image | ||||
|   bind:ref | ||||
| 	class={cn("aspect-square h-full w-full", className)} | ||||
|   class={cn('aspect-square h-full w-full', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Avatar as AvatarPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Avatar as AvatarPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <AvatarPrimitive.Root | ||||
|   bind:ref | ||||
| 	class={cn("relative flex size-10 shrink-0 overflow-hidden rounded-full", className)} | ||||
|   class={cn('relative flex size-10 shrink-0 overflow-hidden rounded-full', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import Root from "./avatar.svelte"; | ||||
| import Image from "./avatar-image.svelte"; | ||||
| import Fallback from "./avatar-fallback.svelte"; | ||||
| import Root from './avatar.svelte'; | ||||
| import Image from './avatar-image.svelte'; | ||||
| import Fallback from './avatar-fallback.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -2,9 +2,7 @@ | ||||
|   const prop: { beatmapId: number } = $props(); | ||||
| </script> | ||||
|  | ||||
| <div | ||||
|   class="absolute w-screen h-screen overflow-hidden pointer-events-none rounded" | ||||
| > | ||||
| <div class="absolute w-screen h-screen overflow-hidden pointer-events-none rounded"> | ||||
|   <div | ||||
|     style="background: url(https://osu.direct/api/media/background/{prop.beatmapId})" | ||||
|     class="absolute top-0 left-0 w-full h-full !bg-cover -z-10 pointer-events-none blur opacity-10 rounded" | ||||
|   | ||||
| @@ -1,37 +1,36 @@ | ||||
| <script lang="ts" module> | ||||
| 	import { type VariantProps, tv } from "tailwind-variants"; | ||||
|   import { type VariantProps, tv } from 'tailwind-variants'; | ||||
|  | ||||
|   export const badgeVariants = tv({ | ||||
| 		base: "focus:ring-ring inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-offset-2", | ||||
|     base: 'focus:ring-ring inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-offset-2', | ||||
|     variants: { | ||||
|       variant: { | ||||
| 				default: | ||||
| 					"bg-primary text-primary-foreground hover:bg-primary/80 border-transparent", | ||||
|         default: 'bg-primary text-primary-foreground hover:bg-primary/80 border-transparent', | ||||
|         secondary: | ||||
| 					"bg-secondary text-secondary-foreground hover:bg-secondary/80 border-transparent", | ||||
|           'bg-secondary text-secondary-foreground hover:bg-secondary/80 border-transparent', | ||||
|         destructive: | ||||
| 					"bg-destructive text-destructive-foreground hover:bg-destructive/80 border-transparent", | ||||
| 				outline: "text-foreground", | ||||
|           'bg-destructive text-destructive-foreground hover:bg-destructive/80 border-transparent', | ||||
|         outline: 'text-foreground', | ||||
|       }, | ||||
|     }, | ||||
|     defaultVariants: { | ||||
| 			variant: "default", | ||||
|       variant: 'default', | ||||
|     }, | ||||
|   }); | ||||
|  | ||||
| 	export type BadgeVariant = VariantProps<typeof badgeVariants>["variant"]; | ||||
|   export type BadgeVariant = VariantProps<typeof badgeVariants>['variant']; | ||||
| </script> | ||||
|  | ||||
| <script lang="ts"> | ||||
| 	import type { WithElementRef } from "bits-ui"; | ||||
| 	import type { HTMLAnchorAttributes } from "svelte/elements"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { WithElementRef } from 'bits-ui'; | ||||
|   import type { HTMLAnchorAttributes } from 'svelte/elements'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
|     href, | ||||
|     class: className, | ||||
| 		variant = "default", | ||||
|     variant = 'default', | ||||
|     children, | ||||
|     ...restProps | ||||
|   }: WithElementRef<HTMLAnchorAttributes> & { | ||||
| @@ -40,7 +39,7 @@ | ||||
| </script> | ||||
|  | ||||
| <svelte:element | ||||
| 	this={href ? "a" : "span"} | ||||
|   this={href ? 'a' : 'span'} | ||||
|   bind:this={ref} | ||||
|   {href} | ||||
|   class={cn(badgeVariants({ variant, className }))} | ||||
|   | ||||
| @@ -1,2 +1,2 @@ | ||||
| export { default as Badge } from "./badge.svelte"; | ||||
| export { badgeVariants, type BadgeVariant } from "./badge.svelte"; | ||||
| export { default as Badge } from './badge.svelte'; | ||||
| export { badgeVariants, type BadgeVariant } from './badge.svelte'; | ||||
|   | ||||
| @@ -1,35 +1,34 @@ | ||||
| <script lang="ts" module> | ||||
| 	import type { WithElementRef } from "bits-ui"; | ||||
| 	import type { HTMLAnchorAttributes, HTMLButtonAttributes } from "svelte/elements"; | ||||
| 	import { type VariantProps, tv } from "tailwind-variants"; | ||||
|   import type { WithElementRef } from 'bits-ui'; | ||||
|   import type { HTMLAnchorAttributes, HTMLButtonAttributes } from 'svelte/elements'; | ||||
|   import { type VariantProps, tv } from 'tailwind-variants'; | ||||
|  | ||||
|   export const buttonVariants = tv({ | ||||
| 		base: "ring-offset-background focus-visible:ring-ring inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", | ||||
|     base: 'ring-offset-background focus-visible:ring-ring inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0', | ||||
|     variants: { | ||||
|       variant: { | ||||
| 				default: "bg-primary text-primary-foreground hover:bg-primary/90", | ||||
| 				destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90", | ||||
| 				outline: | ||||
| 					"border-input bg-background hover:bg-accent hover:text-accent-foreground border", | ||||
| 				secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80", | ||||
| 				ghost: "hover:bg-accent hover:text-accent-foreground", | ||||
| 				link: "text-primary underline-offset-4 hover:underline", | ||||
|         default: 'bg-primary text-primary-foreground hover:bg-primary/90', | ||||
|         destructive: 'bg-destructive text-destructive-foreground hover:bg-destructive/90', | ||||
|         outline: 'border-input bg-background hover:bg-accent hover:text-accent-foreground border', | ||||
|         secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/80', | ||||
|         ghost: 'hover:bg-accent hover:text-accent-foreground', | ||||
|         link: 'text-primary underline-offset-4 hover:underline', | ||||
|       }, | ||||
|       size: { | ||||
| 				default: "h-10 px-4 py-2", | ||||
| 				sm: "h-9 rounded-md px-3", | ||||
| 				lg: "h-11 rounded-md px-8", | ||||
| 				icon: "h-10 w-10", | ||||
|         default: 'h-10 px-4 py-2', | ||||
|         sm: 'h-9 rounded-md px-3', | ||||
|         lg: 'h-11 rounded-md px-8', | ||||
|         icon: 'h-10 w-10', | ||||
|       }, | ||||
|     }, | ||||
|     defaultVariants: { | ||||
| 			variant: "default", | ||||
| 			size: "default", | ||||
|       variant: 'default', | ||||
|       size: 'default', | ||||
|     }, | ||||
|   }); | ||||
|  | ||||
| 	export type ButtonVariant = VariantProps<typeof buttonVariants>["variant"]; | ||||
| 	export type ButtonSize = VariantProps<typeof buttonVariants>["size"]; | ||||
|   export type ButtonVariant = VariantProps<typeof buttonVariants>['variant']; | ||||
|   export type ButtonSize = VariantProps<typeof buttonVariants>['size']; | ||||
|  | ||||
|   export type ButtonProps = WithElementRef<HTMLButtonAttributes> & | ||||
|     WithElementRef<HTMLAnchorAttributes> & { | ||||
| @@ -39,27 +38,22 @@ | ||||
| </script> | ||||
|  | ||||
| <script lang="ts"> | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     class: className, | ||||
| 		variant = "default", | ||||
| 		size = "default", | ||||
|     variant = 'default', | ||||
|     size = 'default', | ||||
|     ref = $bindable(null), | ||||
|     href = undefined, | ||||
| 		type = "button", | ||||
|     type = 'button', | ||||
|     children, | ||||
|     ...restProps | ||||
|   }: ButtonProps = $props(); | ||||
| </script> | ||||
|  | ||||
| {#if href} | ||||
| 	<a | ||||
| 		bind:this={ref} | ||||
| 		class={cn(buttonVariants({ variant, size, className }))} | ||||
| 		{href} | ||||
| 		{...restProps} | ||||
| 	> | ||||
|   <a bind:this={ref} class={cn(buttonVariants({ variant, size, className }))} {href} {...restProps}> | ||||
|     {@render children?.()} | ||||
|   </a> | ||||
| {:else} | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import Root, { | ||||
|   type ButtonSize, | ||||
|   type ButtonVariant, | ||||
|   buttonVariants, | ||||
| } from "./button.svelte"; | ||||
| } from './button.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Checkbox as CheckboxPrimitive, type WithoutChildrenOrChild } from "bits-ui"; | ||||
| 	import Check from "@lucide/svelte/icons/check"; | ||||
| 	import Minus from "@lucide/svelte/icons/minus"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Checkbox as CheckboxPrimitive, type WithoutChildrenOrChild } from 'bits-ui'; | ||||
|   import Check from '@lucide/svelte/icons/check'; | ||||
|   import Minus from '@lucide/svelte/icons/minus'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -16,7 +16,7 @@ | ||||
| <CheckboxPrimitive.Root | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"border-primary ring-offset-background focus-visible:ring-ring data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground peer box-content size-4 shrink-0 rounded-sm border focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[disabled=true]:cursor-not-allowed data-[disabled=true]:opacity-50", | ||||
|     'border-primary ring-offset-background focus-visible:ring-ring data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground peer box-content size-4 shrink-0 rounded-sm border focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[disabled=true]:cursor-not-allowed data-[disabled=true]:opacity-50', | ||||
|     className | ||||
|   )} | ||||
|   bind:checked | ||||
| @@ -28,7 +28,7 @@ | ||||
|       {#if indeterminate} | ||||
|         <Minus class="size-3.5" /> | ||||
|       {:else} | ||||
| 				<Check class={cn("size-3.5", !checked && "text-transparent")} /> | ||||
|         <Check class={cn('size-3.5', !checked && 'text-transparent')} /> | ||||
|       {/if} | ||||
|     </div> | ||||
|   {/snippet} | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Root from "./checkbox.svelte"; | ||||
| import Root from './checkbox.svelte'; | ||||
| export { | ||||
|   Root, | ||||
|   // | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive, type WithoutChildrenOrChild } from "bits-ui"; | ||||
| 	import Check from "lucide-svelte/icons/check"; | ||||
| 	import Minus from "lucide-svelte/icons/minus"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
| 	import type { Snippet } from "svelte"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive, type WithoutChildrenOrChild } from 'bits-ui'; | ||||
|   import Check from 'lucide-svelte/icons/check'; | ||||
|   import Minus from 'lucide-svelte/icons/minus'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|   import type { Snippet } from 'svelte'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -22,7 +22,7 @@ | ||||
|   bind:checked | ||||
|   bind:indeterminate | ||||
|   class={cn( | ||||
| 		"data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50", | ||||
|     'data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
| @@ -32,7 +32,7 @@ | ||||
|       {#if indeterminate} | ||||
|         <Minus class="size-4" /> | ||||
|       {:else} | ||||
| 				<Check class={cn("size-4", !checked && "text-transparent")} /> | ||||
|         <Check class={cn('size-4', !checked && 'text-transparent')} /> | ||||
|       {/if} | ||||
|     </span> | ||||
|     {@render childrenProp?.()} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -18,7 +18,7 @@ | ||||
|     bind:ref | ||||
|     {sideOffset} | ||||
|     class={cn( | ||||
| 			"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 min-w-[8rem] overflow-hidden rounded-md border p-1 shadow-md outline-none", | ||||
|       'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 min-w-[8rem] overflow-hidden rounded-md border p-1 shadow-md outline-none', | ||||
|       className | ||||
|     )} | ||||
|     {...restProps} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -14,6 +14,6 @@ | ||||
|  | ||||
| <DropdownMenuPrimitive.GroupHeading | ||||
|   bind:ref | ||||
| 	class={cn("px-2 py-1.5 text-sm font-semibold", inset && "pl-8", className)} | ||||
|   class={cn('px-2 py-1.5 text-sm font-semibold', inset && 'pl-8', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -15,8 +15,8 @@ | ||||
| <DropdownMenuPrimitive.Item | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none transition-colors data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", | ||||
| 		inset && "pl-8", | ||||
|     'data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none transition-colors data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0', | ||||
|     inset && 'pl-8', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
| 	import { type WithElementRef } from "bits-ui"; | ||||
| 	import type { HTMLAttributes } from "svelte/elements"; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|   import { type WithElementRef } from 'bits-ui'; | ||||
|   import type { HTMLAttributes } from 'svelte/elements'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -16,7 +16,7 @@ | ||||
|  | ||||
| <div | ||||
|   bind:this={ref} | ||||
| 	class={cn("px-2 py-1.5 text-sm font-semibold", inset && "pl-8", className)} | ||||
|   class={cn('px-2 py-1.5 text-sm font-semibold', inset && 'pl-8', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   {@render children?.()} | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive, type WithoutChild } from "bits-ui"; | ||||
| 	import Circle from "lucide-svelte/icons/circle"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive, type WithoutChild } from 'bits-ui'; | ||||
|   import Circle from 'lucide-svelte/icons/circle'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -14,7 +14,7 @@ | ||||
| <DropdownMenuPrimitive.RadioItem | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50", | ||||
|     'data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <DropdownMenuPrimitive.Separator | ||||
|   bind:ref | ||||
| 	class={cn("bg-muted -mx-1 my-1 h-px", className)} | ||||
|   class={cn('bg-muted -mx-1 my-1 h-px', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import type { HTMLAttributes } from "svelte/elements"; | ||||
| 	import { type WithElementRef } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { HTMLAttributes } from 'svelte/elements'; | ||||
|   import { type WithElementRef } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -13,7 +13,7 @@ | ||||
|  | ||||
| <span | ||||
|   bind:this={ref} | ||||
| 	class={cn("ml-auto text-xs tracking-widest opacity-60", className)} | ||||
|   class={cn('ml-auto text-xs tracking-widest opacity-60', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   {@render children?.()} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
| <DropdownMenuPrimitive.SubContent | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"bg-popover text-popover-foreground z-50 min-w-[8rem] rounded-md border p-1 shadow-lg focus:outline-none", | ||||
|     'bg-popover text-popover-foreground z-50 min-w-[8rem] rounded-md border p-1 shadow-lg focus:outline-none', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
| 	import ChevronRight from "lucide-svelte/icons/chevron-right"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
|   import ChevronRight from 'lucide-svelte/icons/chevron-right'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -17,8 +17,8 @@ | ||||
| <DropdownMenuPrimitive.SubTrigger | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"data-[highlighted]:bg-accent data-[state=open]:bg-accent flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", | ||||
| 		inset && "pl-8", | ||||
|     'data-[highlighted]:bg-accent data-[state=open]:bg-accent flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0', | ||||
|     inset && 'pl-8', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| import { DropdownMenu as DropdownMenuPrimitive } from "bits-ui"; | ||||
| import CheckboxItem from "./dropdown-menu-checkbox-item.svelte"; | ||||
| import Content from "./dropdown-menu-content.svelte"; | ||||
| import GroupHeading from "./dropdown-menu-group-heading.svelte"; | ||||
| import Item from "./dropdown-menu-item.svelte"; | ||||
| import Label from "./dropdown-menu-label.svelte"; | ||||
| import RadioItem from "./dropdown-menu-radio-item.svelte"; | ||||
| import Separator from "./dropdown-menu-separator.svelte"; | ||||
| import Shortcut from "./dropdown-menu-shortcut.svelte"; | ||||
| import SubContent from "./dropdown-menu-sub-content.svelte"; | ||||
| import SubTrigger from "./dropdown-menu-sub-trigger.svelte"; | ||||
| import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | ||||
| import CheckboxItem from './dropdown-menu-checkbox-item.svelte'; | ||||
| import Content from './dropdown-menu-content.svelte'; | ||||
| import GroupHeading from './dropdown-menu-group-heading.svelte'; | ||||
| import Item from './dropdown-menu-item.svelte'; | ||||
| import Label from './dropdown-menu-label.svelte'; | ||||
| import RadioItem from './dropdown-menu-radio-item.svelte'; | ||||
| import Separator from './dropdown-menu-separator.svelte'; | ||||
| import Shortcut from './dropdown-menu-shortcut.svelte'; | ||||
| import SubContent from './dropdown-menu-sub-content.svelte'; | ||||
| import SubTrigger from './dropdown-menu-sub-trigger.svelte'; | ||||
|  | ||||
| const Sub = DropdownMenuPrimitive.Sub; | ||||
| const Root = DropdownMenuPrimitive.Root; | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Root from "./input.svelte"; | ||||
| import Root from './input.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import type { HTMLInputAttributes } from "svelte/elements"; | ||||
| 	import type { WithElementRef } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { HTMLInputAttributes } from 'svelte/elements'; | ||||
|   import type { WithElementRef } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -14,7 +14,7 @@ | ||||
| <input | ||||
|   bind:this={ref} | ||||
|   class={cn( | ||||
| 		"border-input bg-background ring-offset-background placeholder:text-muted-foreground focus-visible:ring-ring flex h-10 w-full rounded-md border px-3 py-2 text-sm file:border-0 file:bg-transparent file:text-sm file:font-medium focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50", | ||||
|     'border-input bg-background ring-offset-background placeholder:text-muted-foreground focus-visible:ring-ring flex h-10 w-full rounded-md border px-3 py-2 text-sm file:border-0 file:bg-transparent file:text-sm file:font-medium focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50', | ||||
|     className | ||||
|   )} | ||||
|   bind:value | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Root from "./label.svelte"; | ||||
| import Root from './label.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Label as LabelPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Label as LabelPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
| <LabelPrimitive.Root | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70", | ||||
|     'text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| <script lang="ts"> | ||||
|   import ezppLogo from "../../../../assets/logo.png"; | ||||
|   import { osudirect } from "@/api/osudirect"; | ||||
|   import { gameSounds, playAudio } from "@/utils"; | ||||
|   import { BeatmapDecoder } from "osu-parsers"; | ||||
|   import { onMount } from "svelte"; | ||||
|   import ezppLogo from '../../../../assets/logo.png'; | ||||
|   import { osudirect } from '@/api/osudirect'; | ||||
|   import { gameSounds } from '@/utils'; | ||||
|   import { BeatmapDecoder } from 'osu-parsers'; | ||||
|   import { onMount } from 'svelte'; | ||||
|  | ||||
|   type logoProps = { | ||||
|     beatmapId: number; | ||||
| @@ -26,14 +26,12 @@ | ||||
|       const beatmap = decoder.decodeFromString(beatmapData); | ||||
|       console.log(beatmap); | ||||
|  | ||||
|       const audio = new Audio( | ||||
|         `https://osu.direct/api/media/audio/${beatmapId}` | ||||
|       ); | ||||
|       const audio = new Audio(`https://osu.direct/api/media/audio/${beatmapId}`); | ||||
|       audio.volume = 0.3; | ||||
|  | ||||
|       // Function to play the heartbeat sound | ||||
|       const playHeartbeat = () => { | ||||
|         gameSounds.play("menuHeartbeat", { | ||||
|         gameSounds.play('menuHeartbeat', { | ||||
|           volume: hovered ? 1 : 0.3, | ||||
|         }); | ||||
|       }; | ||||
| @@ -60,8 +58,7 @@ | ||||
|               window.clearInterval(lastTimeout); | ||||
|               lastTimeout = undefined; | ||||
|             } | ||||
|             if (!lastTimeout) | ||||
|               lastTimeout = window.setInterval(playHeartbeat, interval); | ||||
|             if (!lastTimeout) lastTimeout = window.setInterval(playHeartbeat, interval); | ||||
|           }, nextBeat); | ||||
|         } | ||||
|         // Continue syncing | ||||
| @@ -69,9 +66,9 @@ | ||||
|       }; | ||||
|  | ||||
|       // Wait for audio to be ready before starting playback and syncing | ||||
|       audio.addEventListener("canplay", async () => { | ||||
|         audio.addEventListener("play", syncHeartbeat); | ||||
|         audio.addEventListener("ended", async () => await audio.play()); | ||||
|       audio.addEventListener('canplay', async () => { | ||||
|         audio.addEventListener('play', syncHeartbeat); | ||||
|         audio.addEventListener('ended', async () => await audio.play()); | ||||
|         await audio.play(); | ||||
|         syncHeartbeat(); | ||||
|       }); | ||||
| @@ -96,9 +93,9 @@ | ||||
|     onmouseleave={() => (hovered = false)} | ||||
|     onclick={() => { | ||||
|       if (extended) { | ||||
|         gameSounds.play("menuBack"); | ||||
|         gameSounds.play('menuBack'); | ||||
|       } else { | ||||
|         gameSounds.play("menuHit"); | ||||
|         gameSounds.play('menuHit'); | ||||
|       } | ||||
|       onclick(); | ||||
|     }} | ||||
|   | ||||
| @@ -3,8 +3,6 @@ | ||||
|   import cursor_additive from '$assets/cursor-additive.png'; | ||||
|   import { animate } from 'animejs'; | ||||
|   import { onMount } from 'svelte'; | ||||
|   import { currentMonitor } from '@tauri-apps/api/window'; | ||||
|   import { estimateRefreshRate } from '@/displayUtils'; | ||||
|   import { cursorSmoothness } from '@/userSettings'; | ||||
|  | ||||
|   let { smoothCursor = true }: { smoothCursor?: boolean } = $props(); | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Root from "./progress.svelte"; | ||||
| import Root from './progress.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -20,7 +20,9 @@ | ||||
|   {...restProps} | ||||
| > | ||||
|   <div | ||||
|     class="bg-primary h-full w-full flex-1 transition-all {indeterminate ? 'animate-slide' : ''} rounded-lg" | ||||
|     class="bg-primary h-full w-full flex-1 transition-all {indeterminate | ||||
|       ? 'animate-slide' | ||||
|       : ''} rounded-lg" | ||||
|     style={`transform: translateX(-${100 - (100 * ((indeterminate ? max : value) ?? 0)) / (max ?? 1)}%);`} | ||||
|   ></div> | ||||
| </ProgressPrimitive.Root> | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| import { Select as SelectPrimitive } from "bits-ui"; | ||||
| import { Select as SelectPrimitive } from 'bits-ui'; | ||||
|  | ||||
| import GroupHeading from "./select-group-heading.svelte"; | ||||
| import Item from "./select-item.svelte"; | ||||
| import Content from "./select-content.svelte"; | ||||
| import Trigger from "./select-trigger.svelte"; | ||||
| import Separator from "./select-separator.svelte"; | ||||
| import ScrollDownButton from "./select-scroll-down-button.svelte"; | ||||
| import ScrollUpButton from "./select-scroll-up-button.svelte"; | ||||
| import GroupHeading from './select-group-heading.svelte'; | ||||
| import Item from './select-item.svelte'; | ||||
| import Content from './select-content.svelte'; | ||||
| import Trigger from './select-trigger.svelte'; | ||||
| import Separator from './select-separator.svelte'; | ||||
| import ScrollDownButton from './select-scroll-down-button.svelte'; | ||||
| import ScrollUpButton from './select-scroll-up-button.svelte'; | ||||
|  | ||||
| const Root = SelectPrimitive.Root; | ||||
| const Group = SelectPrimitive.Group; | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Select as SelectPrimitive, type WithoutChild } from "bits-ui"; | ||||
| 	import SelectScrollUpButton from "./select-scroll-up-button.svelte"; | ||||
| 	import SelectScrollDownButton from "./select-scroll-down-button.svelte"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Select as SelectPrimitive, type WithoutChild } from 'bits-ui'; | ||||
|   import SelectScrollUpButton from './select-scroll-up-button.svelte'; | ||||
|   import SelectScrollDownButton from './select-scroll-down-button.svelte'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -21,7 +21,7 @@ | ||||
|     bind:ref | ||||
|     {sideOffset} | ||||
|     class={cn( | ||||
| 			"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-popover text-popover-foreground relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border shadow-md data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1", | ||||
|       'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-popover text-popover-foreground relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border shadow-md data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1', | ||||
|       className | ||||
|     )} | ||||
|     {...restProps} | ||||
| @@ -29,7 +29,7 @@ | ||||
|     <SelectScrollUpButton /> | ||||
|     <SelectPrimitive.Viewport | ||||
|       class={cn( | ||||
| 				"h-[var(--bits-select-anchor-height)] w-full min-w-[var(--bits-select-anchor-width)] p-1" | ||||
|         'h-[var(--bits-select-anchor-height)] w-full min-w-[var(--bits-select-anchor-width)] p-1' | ||||
|       )} | ||||
|     > | ||||
|       {@render children?.()} | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Select as SelectPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Select as SelectPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -11,6 +11,6 @@ | ||||
|  | ||||
| <SelectPrimitive.GroupHeading | ||||
|   bind:ref | ||||
| 	class={cn("py-1.5 pl-8 pr-2 text-sm font-semibold", className)} | ||||
|   class={cn('py-1.5 pl-8 pr-2 text-sm font-semibold', className)} | ||||
|   {...restProps} | ||||
| /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import Check from "@lucide/svelte/icons/check"; | ||||
| 	import { Select as SelectPrimitive, type WithoutChild } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import Check from '@lucide/svelte/icons/check'; | ||||
|   import { Select as SelectPrimitive, type WithoutChild } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -17,7 +17,7 @@ | ||||
|   bind:ref | ||||
|   {value} | ||||
|   class={cn( | ||||
| 		"data-[highlighted]:bg-primary-800/30 data-[highlighted]:text-accent-foreground relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50", | ||||
|     'data-[highlighted]:bg-primary-800/30 data-[highlighted]:text-accent-foreground relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import ChevronDown from "@lucide/svelte/icons/chevron-down"; | ||||
| 	import { Select as SelectPrimitive, type WithoutChildrenOrChild } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import ChevronDown from '@lucide/svelte/icons/chevron-down'; | ||||
|   import { Select as SelectPrimitive, type WithoutChildrenOrChild } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
|  | ||||
| <SelectPrimitive.ScrollDownButton | ||||
|   bind:ref | ||||
| 	class={cn("flex cursor-default items-center justify-center py-1", className)} | ||||
|   class={cn('flex cursor-default items-center justify-center py-1', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   <ChevronDown class="size-4" /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import ChevronUp from "@lucide/svelte/icons/chevron-up"; | ||||
| 	import { Select as SelectPrimitive, type WithoutChildrenOrChild } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import ChevronUp from '@lucide/svelte/icons/chevron-up'; | ||||
|   import { Select as SelectPrimitive, type WithoutChildrenOrChild } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -12,7 +12,7 @@ | ||||
|  | ||||
| <SelectPrimitive.ScrollUpButton | ||||
|   bind:ref | ||||
| 	class={cn("flex cursor-default items-center justify-center py-1", className)} | ||||
|   class={cn('flex cursor-default items-center justify-center py-1', className)} | ||||
|   {...restProps} | ||||
| > | ||||
|   <ChevronUp class="size-4" /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import type { Separator as SeparatorPrimitive } from "bits-ui"; | ||||
| 	import { Separator } from "$lib/components/ui/separator/index.js"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import type { Separator as SeparatorPrimitive } from 'bits-ui'; | ||||
|   import { Separator } from '$lib/components/ui/separator/index.js'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -10,4 +10,4 @@ | ||||
|   }: SeparatorPrimitive.RootProps = $props(); | ||||
| </script> | ||||
|  | ||||
| <Separator bind:ref class={cn("bg-muted -mx-1 my-1 h-px", className)} {...restProps} /> | ||||
| <Separator bind:ref class={cn('bg-muted -mx-1 my-1 h-px', className)} {...restProps} /> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Select as SelectPrimitive, type WithoutChild } from "bits-ui"; | ||||
| 	import ChevronDown from "@lucide/svelte/icons/chevron-down"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Select as SelectPrimitive, type WithoutChild } from 'bits-ui'; | ||||
|   import ChevronDown from '@lucide/svelte/icons/chevron-down'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
| @@ -14,7 +14,7 @@ | ||||
| <SelectPrimitive.Trigger | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"border-input bg-background ring-offset-background data-[placeholder]:text-muted-foreground focus:ring-ring flex h-10 w-full items-center justify-between rounded-md border px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1", | ||||
|     'border-input bg-background ring-offset-background data-[placeholder]:text-muted-foreground focus:ring-ring flex h-10 w-full items-center justify-between rounded-md border px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1', | ||||
|     className | ||||
|   )} | ||||
|   {...restProps} | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import Root from "./separator.svelte"; | ||||
| import Root from './separator.svelte'; | ||||
|  | ||||
| export { | ||||
|   Root, | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| <script lang="ts"> | ||||
| 	import { Separator as SeparatorPrimitive } from "bits-ui"; | ||||
| 	import { cn } from "$lib/utils.js"; | ||||
|   import { Separator as SeparatorPrimitive } from 'bits-ui'; | ||||
|   import { cn } from '$lib/utils.js'; | ||||
|  | ||||
|   let { | ||||
|     ref = $bindable(null), | ||||
|     class: className, | ||||
| 		orientation = "horizontal", | ||||
|     orientation = 'horizontal', | ||||
|     ...restProps | ||||
|   }: SeparatorPrimitive.RootProps = $props(); | ||||
| </script> | ||||
| @@ -13,8 +13,8 @@ | ||||
| <SeparatorPrimitive.Root | ||||
|   bind:ref | ||||
|   class={cn( | ||||
| 		"bg-border shrink-0", | ||||
| 		orientation === "horizontal" ? "h-[1px] w-full" : "min-h-full w-[1px]", | ||||
|     'bg-border shrink-0', | ||||
|     orientation === 'horizontal' ? 'h-[1px] w-full' : 'min-h-full w-[1px]', | ||||
|     className | ||||
|   )} | ||||
|   {orientation} | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| export { default as Toaster } from "./sonner.svelte"; | ||||
| export { default as Toaster } from './sonner.svelte'; | ||||
|   | ||||
| @@ -45,6 +45,7 @@ export class Config { | ||||
|       ) as Record<string, unknown>; | ||||
|       this.config = decryptedJSON; | ||||
|     } catch (err) { | ||||
|       console.log(err); | ||||
|       this.config = {}; | ||||
|       await this.save(); | ||||
|     } | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| export function estimateRefreshRate(): Promise<number> { | ||||
|   return new Promise((resolve) => { | ||||
|     let last = performance.now(); | ||||
|     const last = performance.now(); | ||||
|     let frames = 0; | ||||
|  | ||||
|     function loop() { | ||||
|   | ||||
| @@ -22,7 +22,7 @@ export const skins = writable<number | undefined>(undefined); | ||||
| export const osuStream = writable<string | undefined>(undefined); | ||||
| export const osuBuild = writable<string | undefined>(undefined); | ||||
|  | ||||
| export const currentSkin = writable<string>(""); | ||||
| export const currentSkin = writable<string>(''); | ||||
|  | ||||
| let updateValues = true; | ||||
| launching.subscribe((val) => (updateValues = !val)); | ||||
|   | ||||
| @@ -70,7 +70,8 @@ export const getSkin = async (folder: string) => { | ||||
| }; | ||||
|  | ||||
| export const runUpdater = async (folder: string) => await invoke('run_osu_updater', { folder }); | ||||
| export const runOsu = async (folder: string, patch: boolean) => await invoke('run_osu', { folder, patch }); | ||||
| export const runOsu = async (folder: string, patch: boolean) => | ||||
|   await invoke('run_osu', { folder, patch }); | ||||
|  | ||||
| export const getEZPPLauncherUpdateFiles = async (folder: string) => { | ||||
|   const result = await invoke('get_ezpp_launcher_update_files', { folder, updateUrl }); | ||||
|   | ||||
| @@ -2,5 +2,5 @@ import { writable } from 'svelte/store'; | ||||
| import { Config } from './config'; | ||||
| import type { EZPPUser } from './types'; | ||||
|  | ||||
| export const userAuth = writable<Config>(new Config("user_auth", true)); | ||||
| export const userAuth = writable<Config>(new Config('user_auth', true)); | ||||
| export const currentUser = writable<EZPPUser | undefined>(undefined); | ||||
|   | ||||
| @@ -144,7 +144,7 @@ | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   const launch = async (offline: boolean) => { | ||||
|   const launch = async () => { | ||||
|     const osuRunning = await isOsuRunning(); | ||||
|     if (osuRunning) { | ||||
|       toast.error('Hold on a second!', { | ||||
| @@ -347,7 +347,7 @@ | ||||
|     </div> | ||||
|     <div class="flex flex-col items-center justify-center gap-2 p-3 rounded-lg"> | ||||
|       <Progress indeterminate={progress === -1} value={progress} /> | ||||
|       <span class="text-muted-foreground">{launchInfo}</span> | ||||
|       <span class="text-muted-foreground text-sm mt-4">{launchInfo}</span> | ||||
|     </div> | ||||
|   </AlertDialog.Content> | ||||
| </AlertDialog.Root> | ||||
| @@ -428,7 +428,7 @@ | ||||
|               </div> | ||||
|             </Select.Trigger> | ||||
|             <Select.Content class="bg-theme-950 border border-theme-900 rounded-lg"> | ||||
|               {#each validModeTypeCombinationsSorted as gamemode} | ||||
|               {#each validModeTypeCombinationsSorted as gamemode (gamemode)} | ||||
|                 {@const gamemod = getModeAndTypeFromGamemode(gamemode)} | ||||
|                 <Select.Item value={gamemode.toFixed()}> | ||||
|                   <div class="flex flex-row gap-2 items-center"> | ||||
| @@ -471,11 +471,17 @@ | ||||
|               <div class="flex items-center h-full text-lg font-semibold text-theme-50"> | ||||
|                 {#if $currentUserInfo} | ||||
|                   <div in:fade> | ||||
|                     {#if $reduceAnimations} | ||||
|                       <span> | ||||
|                         #{numberHumanReadable($currentUserInfo.stats[selectedGamemode].rank ?? 0)} | ||||
|                       </span> | ||||
|                     {:else} | ||||
|                       <NumberFlow | ||||
|                         trend={0} | ||||
|                         prefix="#" | ||||
|                         value={$currentUserInfo.stats[selectedGamemode].rank ?? 0} | ||||
|                     ></NumberFlow> | ||||
|                       /> | ||||
|                     {/if} | ||||
|                   </div> | ||||
|                 {:else} | ||||
|                   <div in:fade> | ||||
| @@ -489,8 +495,16 @@ | ||||
|               <div class="flex items-center h-full text-lg font-semibold text-theme-50"> | ||||
|                 {#if $currentUserInfo} | ||||
|                   <div in:fade> | ||||
|                     <NumberFlow trend={0} value={$currentUserInfo.stats[selectedGamemode].pp ?? 0} | ||||
|                     ></NumberFlow> | ||||
|                     {#if $reduceAnimations} | ||||
|                       <span> | ||||
|                         {numberHumanReadable($currentUserInfo.stats[selectedGamemode].pp ?? 0)} | ||||
|                       </span> | ||||
|                     {:else} | ||||
|                       <NumberFlow | ||||
|                         trend={0} | ||||
|                         value={$currentUserInfo.stats[selectedGamemode].pp ?? 0} | ||||
|                       /> | ||||
|                     {/if} | ||||
|                   </div> | ||||
|                 {:else} | ||||
|                   <div in:fade> | ||||
| @@ -507,11 +521,16 @@ | ||||
|             > | ||||
|               {#if $currentUserInfo} | ||||
|                 <div in:fade> | ||||
|                   {#if $reduceAnimations} | ||||
|                     <span>{($currentUserInfo.stats[selectedGamemode].acc ?? 0).toFixed(2)}%</span> | ||||
|                   {:else} | ||||
|                     <NumberFlow | ||||
|                       class="leading-none" | ||||
|                       trend={0} | ||||
|                       suffix="%" | ||||
|                     value={$currentUserInfo.stats[selectedGamemode].acc.toFixed(2) ?? 0} | ||||
|                   ></NumberFlow> | ||||
|                       value={($currentUserInfo.stats[selectedGamemode].acc ?? 0).toFixed(2)} | ||||
|                     /> | ||||
|                   {/if} | ||||
|                 </div> | ||||
|               {:else} | ||||
|                 <div in:fade> | ||||
| @@ -526,8 +545,19 @@ | ||||
|             > | ||||
|               {#if $currentUserInfo} | ||||
|                 <div in:fade> | ||||
|                   <NumberFlow trend={0} value={$currentUserInfo.stats[selectedGamemode].plays ?? 0} | ||||
|                   ></NumberFlow> | ||||
|                   {#if $reduceAnimations} | ||||
|                     <span | ||||
|                       >{numberHumanReadable( | ||||
|                         $currentUserInfo.stats[selectedGamemode].plays ?? 0 | ||||
|                       )}</span | ||||
|                     > | ||||
|                   {:else} | ||||
|                     <NumberFlow | ||||
|                       class="leading-none" | ||||
|                       trend={0} | ||||
|                       value={$currentUserInfo.stats[selectedGamemode].plays ?? 0} | ||||
|                     /> | ||||
|                   {/if} | ||||
|                 </div> | ||||
|               {:else} | ||||
|                 <div in:fade> | ||||
| @@ -726,11 +756,11 @@ | ||||
|         </div> | ||||
|         <Button | ||||
|           size="lg" | ||||
|           disabled={$launching || $osuInstallationPath === ''} | ||||
|           onclick={() => launch($serverConnectionFails > 1)} | ||||
|           disabled={$launching || $osuInstallationPath === '' || $serverConnectionFails > 1} | ||||
|           onclick={launch} | ||||
|         > | ||||
|           <Play /> | ||||
|           Launch {$serverConnectionFails > 1 ? 'offline' : ''} | ||||
|           {$serverConnectionFails > 1 ? 'No connection' : 'Launch'} | ||||
|         </Button> | ||||
|       </div> | ||||
|       <div | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| // Tauri doesn't have a Node.js server to do proper SSR | ||||
| // so we will use adapter-static to prerender the app (SSG) | ||||
| // See: https://v2.tauri.app/start/frontend/sveltekit/ for more info | ||||
| import adapter from "@sveltejs/adapter-static"; | ||||
| import { vitePreprocess } from "@sveltejs/vite-plugin-svelte"; | ||||
| import adapter from '@sveltejs/adapter-static'; | ||||
| import { vitePreprocess } from '@sveltejs/vite-plugin-svelte'; | ||||
|  | ||||
| /** @type {import('@sveltejs/kit').Config} */ | ||||
| const config = { | ||||
| @@ -10,10 +10,10 @@ const config = { | ||||
|   kit: { | ||||
|     adapter: adapter(), | ||||
|     alias: { | ||||
|       '@/*': "./src/lib/*", | ||||
|       "$lib/*": "./src/lib/*", | ||||
|       "$assets/*": "./src/assets/*" | ||||
|     } | ||||
|       '@/*': './src/lib/*', | ||||
|       '$lib/*': './src/lib/*', | ||||
|       '$assets/*': './src/assets/*', | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -9,8 +9,8 @@ | ||||
|     "skipLibCheck": true, | ||||
|     "sourceMap": true, | ||||
|     "strict": true, | ||||
|     "moduleResolution": "bundler", | ||||
|   }, | ||||
|     "moduleResolution": "bundler" | ||||
|   } | ||||
|   // Path aliases are handled by https://kit.svelte.dev/docs/configuration#alias | ||||
|   // except $lib which is handled by https://kit.svelte.dev/docs/configuration#files | ||||
|   // | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { defineConfig } from "vite"; | ||||
| import { sveltekit } from "@sveltejs/kit/vite"; | ||||
| import { defineConfig } from 'vite'; | ||||
| import { sveltekit } from '@sveltejs/kit/vite'; | ||||
| import devtoolsJson from 'vite-plugin-devtools-json'; | ||||
|  | ||||
| // @ts-expect-error process is a nodejs global | ||||
| @@ -20,14 +20,14 @@ export default defineConfig(async () => ({ | ||||
|     host: host || false, | ||||
|     hmr: host | ||||
|       ? { | ||||
|           protocol: "ws", | ||||
|           protocol: 'ws', | ||||
|           host, | ||||
|           port: 1421, | ||||
|         } | ||||
|       : undefined, | ||||
|     watch: { | ||||
|       // 3. tell vite to ignore watching `src-tauri` | ||||
|       ignored: ["**/src-tauri/**"], | ||||
|       ignored: ['**/src-tauri/**'], | ||||
|     }, | ||||
|   }, | ||||
| })); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user