diff --git a/bun.lock b/bun.lock new file mode 100644 index 00000000..a4187dc8 --- /dev/null +++ b/bun.lock @@ -0,0 +1,460 @@ +{ + "lockfileVersion": 1, + "workspaces": { + "": { + "name": "arcade", + "devDependencies": { + "@types/node": "^22.15.23", + "change-case": "^5.4.4", + "csv-parser": "^3.2.0", + "eslint": "^9.12.0", + "prettier": "^3.5.3", + "tsup": "^8.3.5", + "turbo": "^2.4.4", + }, + }, + }, + "packages": { + "@esbuild/aix-ppc64": ["@esbuild/aix-ppc64@0.25.5", "", { "os": "aix", "cpu": "ppc64" }, "sha512-9o3TMmpmftaCMepOdA5k/yDw8SfInyzWWTjYTFCX3kPSDJMROQTb8jg+h9Cnwnmm1vOzvxN7gIfB5V2ewpjtGA=="], + + "@esbuild/android-arm": ["@esbuild/android-arm@0.25.5", "", { "os": "android", "cpu": "arm" }, "sha512-AdJKSPeEHgi7/ZhuIPtcQKr5RQdo6OO2IL87JkianiMYMPbCtot9fxPbrMiBADOWWm3T2si9stAiVsGbTQFkbA=="], + + "@esbuild/android-arm64": ["@esbuild/android-arm64@0.25.5", "", { "os": "android", "cpu": "arm64" }, "sha512-VGzGhj4lJO+TVGV1v8ntCZWJktV7SGCs3Pn1GRWI1SBFtRALoomm8k5E9Pmwg3HOAal2VDc2F9+PM/rEY6oIDg=="], + + "@esbuild/android-x64": ["@esbuild/android-x64@0.25.5", "", { "os": "android", "cpu": "x64" }, "sha512-D2GyJT1kjvO//drbRT3Hib9XPwQeWd9vZoBJn+bu/lVsOZ13cqNdDeqIF/xQ5/VmWvMduP6AmXvylO/PIc2isw=="], + + "@esbuild/darwin-arm64": ["@esbuild/darwin-arm64@0.25.5", "", { "os": "darwin", "cpu": "arm64" }, "sha512-GtaBgammVvdF7aPIgH2jxMDdivezgFu6iKpmT+48+F8Hhg5J/sfnDieg0aeG/jfSvkYQU2/pceFPDKlqZzwnfQ=="], + + "@esbuild/darwin-x64": ["@esbuild/darwin-x64@0.25.5", "", { "os": "darwin", "cpu": "x64" }, "sha512-1iT4FVL0dJ76/q1wd7XDsXrSW+oLoquptvh4CLR4kITDtqi2e/xwXwdCVH8hVHU43wgJdsq7Gxuzcs6Iq/7bxQ=="], + + "@esbuild/freebsd-arm64": ["@esbuild/freebsd-arm64@0.25.5", "", { "os": "freebsd", "cpu": "arm64" }, "sha512-nk4tGP3JThz4La38Uy/gzyXtpkPW8zSAmoUhK9xKKXdBCzKODMc2adkB2+8om9BDYugz+uGV7sLmpTYzvmz6Sw=="], + + "@esbuild/freebsd-x64": ["@esbuild/freebsd-x64@0.25.5", "", { "os": "freebsd", "cpu": "x64" }, "sha512-PrikaNjiXdR2laW6OIjlbeuCPrPaAl0IwPIaRv+SMV8CiM8i2LqVUHFC1+8eORgWyY7yhQY+2U2fA55mBzReaw=="], + + "@esbuild/linux-arm": ["@esbuild/linux-arm@0.25.5", "", { "os": "linux", "cpu": "arm" }, "sha512-cPzojwW2okgh7ZlRpcBEtsX7WBuqbLrNXqLU89GxWbNt6uIg78ET82qifUy3W6OVww6ZWobWub5oqZOVtwolfw=="], + + "@esbuild/linux-arm64": ["@esbuild/linux-arm64@0.25.5", "", { "os": "linux", "cpu": "arm64" }, "sha512-Z9kfb1v6ZlGbWj8EJk9T6czVEjjq2ntSYLY2cw6pAZl4oKtfgQuS4HOq41M/BcoLPzrUbNd+R4BXFyH//nHxVg=="], + + "@esbuild/linux-ia32": ["@esbuild/linux-ia32@0.25.5", "", { "os": "linux", "cpu": "ia32" }, "sha512-sQ7l00M8bSv36GLV95BVAdhJ2QsIbCuCjh/uYrWiMQSUuV+LpXwIqhgJDcvMTj+VsQmqAHL2yYaasENvJ7CDKA=="], + + "@esbuild/linux-loong64": ["@esbuild/linux-loong64@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-0ur7ae16hDUC4OL5iEnDb0tZHDxYmuQyhKhsPBV8f99f6Z9KQM02g33f93rNH5A30agMS46u2HP6qTdEt6Q1kg=="], + + "@esbuild/linux-mips64el": ["@esbuild/linux-mips64el@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-kB/66P1OsHO5zLz0i6X0RxlQ+3cu0mkxS3TKFvkb5lin6uwZ/ttOkP3Z8lfR9mJOBk14ZwZ9182SIIWFGNmqmg=="], + + "@esbuild/linux-ppc64": ["@esbuild/linux-ppc64@0.25.5", "", { "os": "linux", "cpu": "ppc64" }, "sha512-UZCmJ7r9X2fe2D6jBmkLBMQetXPXIsZjQJCjgwpVDz+YMcS6oFR27alkgGv3Oqkv07bxdvw7fyB71/olceJhkQ=="], + + "@esbuild/linux-riscv64": ["@esbuild/linux-riscv64@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-kTxwu4mLyeOlsVIFPfQo+fQJAV9mh24xL+y+Bm6ej067sYANjyEw1dNHmvoqxJUCMnkBdKpvOn0Ahql6+4VyeA=="], + + "@esbuild/linux-s390x": ["@esbuild/linux-s390x@0.25.5", "", { "os": "linux", "cpu": "s390x" }, "sha512-K2dSKTKfmdh78uJ3NcWFiqyRrimfdinS5ErLSn3vluHNeHVnBAFWC8a4X5N+7FgVE1EjXS1QDZbpqZBjfrqMTQ=="], + + "@esbuild/linux-x64": ["@esbuild/linux-x64@0.25.5", "", { "os": "linux", "cpu": "x64" }, "sha512-uhj8N2obKTE6pSZ+aMUbqq+1nXxNjZIIjCjGLfsWvVpy7gKCOL6rsY1MhRh9zLtUtAI7vpgLMK6DxjO8Qm9lJw=="], + + "@esbuild/netbsd-arm64": ["@esbuild/netbsd-arm64@0.25.5", "", { "os": "none", "cpu": "arm64" }, "sha512-pwHtMP9viAy1oHPvgxtOv+OkduK5ugofNTVDilIzBLpoWAM16r7b/mxBvfpuQDpRQFMfuVr5aLcn4yveGvBZvw=="], + + "@esbuild/netbsd-x64": ["@esbuild/netbsd-x64@0.25.5", "", { "os": "none", "cpu": "x64" }, "sha512-WOb5fKrvVTRMfWFNCroYWWklbnXH0Q5rZppjq0vQIdlsQKuw6mdSihwSo4RV/YdQ5UCKKvBy7/0ZZYLBZKIbwQ=="], + + "@esbuild/openbsd-arm64": ["@esbuild/openbsd-arm64@0.25.5", "", { "os": "openbsd", "cpu": "arm64" }, "sha512-7A208+uQKgTxHd0G0uqZO8UjK2R0DDb4fDmERtARjSHWxqMTye4Erz4zZafx7Di9Cv+lNHYuncAkiGFySoD+Mw=="], + + "@esbuild/openbsd-x64": ["@esbuild/openbsd-x64@0.25.5", "", { "os": "openbsd", "cpu": "x64" }, "sha512-G4hE405ErTWraiZ8UiSoesH8DaCsMm0Cay4fsFWOOUcz8b8rC6uCvnagr+gnioEjWn0wC+o1/TAHt+It+MpIMg=="], + + "@esbuild/sunos-x64": ["@esbuild/sunos-x64@0.25.5", "", { "os": "sunos", "cpu": "x64" }, "sha512-l+azKShMy7FxzY0Rj4RCt5VD/q8mG/e+mDivgspo+yL8zW7qEwctQ6YqKX34DTEleFAvCIUviCFX1SDZRSyMQA=="], + + "@esbuild/win32-arm64": ["@esbuild/win32-arm64@0.25.5", "", { "os": "win32", "cpu": "arm64" }, "sha512-O2S7SNZzdcFG7eFKgvwUEZ2VG9D/sn/eIiz8XRZ1Q/DO5a3s76Xv0mdBzVM5j5R639lXQmPmSo0iRpHqUUrsxw=="], + + "@esbuild/win32-ia32": ["@esbuild/win32-ia32@0.25.5", "", { "os": "win32", "cpu": "ia32" }, "sha512-onOJ02pqs9h1iMJ1PQphR+VZv8qBMQ77Klcsqv9CNW2w6yLqoURLcgERAIurY6QE63bbLuqgP9ATqajFLK5AMQ=="], + + "@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/config-array": ["@eslint/config-array@0.20.0", "", { "dependencies": { "@eslint/object-schema": "^2.1.6", "debug": "^4.3.1", "minimatch": "^3.1.2" } }, "sha512-fxlS1kkIjx8+vy2SjuCB94q3htSNrufYTXubwiBFeaQHbH6Ipi43gFJq2zCMt6PHhImH3Xmr0NksKDvchWlpQQ=="], + + "@eslint/config-helpers": ["@eslint/config-helpers@0.2.2", "", {}, "sha512-+GPzk8PlG0sPpzdU5ZvIRMPidzAnZDl/s9L+y13iodqvb8leL53bTannOrQ/Im7UkpsmFU5Ily5U60LWixnmLg=="], + + "@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.27.0", "", {}, "sha512-G5JD9Tu5HJEu4z2Uo4aHY2sLV64B7CDMXxFzqzjl3NKd6RVzSXNoE80jk7Y0lJkTTkjiIhBAqmlYwjuBY3tvpA=="], + + "@eslint/object-schema": ["@eslint/object-schema@2.1.6", "", {}, "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA=="], + + "@eslint/plugin-kit": ["@eslint/plugin-kit@0.3.1", "", { "dependencies": { "@eslint/core": "^0.14.0", "levn": "^0.4.1" } }, "sha512-0J+zgWxHN+xXONWIyPWKFMgVuJoZuGiIFu8yxk7RJjxkzpGmyja5wRFqZIVtjDVOQpV+Rw0iOAjYPE2eQyjr0w=="], + + "@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=="], + + "@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=="], + + "@jridgewell/gen-mapping": ["@jridgewell/gen-mapping@0.3.8", "", { "dependencies": { "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", "@jridgewell/trace-mapping": "^0.3.24" } }, "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA=="], + + "@jridgewell/resolve-uri": ["@jridgewell/resolve-uri@3.1.2", "", {}, "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw=="], + + "@jridgewell/set-array": ["@jridgewell/set-array@1.2.1", "", {}, "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A=="], + + "@jridgewell/sourcemap-codec": ["@jridgewell/sourcemap-codec@1.5.0", "", {}, "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ=="], + + "@jridgewell/trace-mapping": ["@jridgewell/trace-mapping@0.3.25", "", { "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", "@jridgewell/sourcemap-codec": "^1.4.14" } }, "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ=="], + + "@pkgjs/parseargs": ["@pkgjs/parseargs@0.11.0", "", {}, "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg=="], + + "@rollup/rollup-android-arm-eabi": ["@rollup/rollup-android-arm-eabi@4.41.1", "", { "os": "android", "cpu": "arm" }, "sha512-NELNvyEWZ6R9QMkiytB4/L4zSEaBC03KIXEghptLGLZWJ6VPrL63ooZQCOnlx36aQPGhzuOMwDerC1Eb2VmrLw=="], + + "@rollup/rollup-android-arm64": ["@rollup/rollup-android-arm64@4.41.1", "", { "os": "android", "cpu": "arm64" }, "sha512-DXdQe1BJ6TK47ukAoZLehRHhfKnKg9BjnQYUu9gzhI8Mwa1d2fzxA1aw2JixHVl403bwp1+/o/NhhHtxWJBgEA=="], + + "@rollup/rollup-darwin-arm64": ["@rollup/rollup-darwin-arm64@4.41.1", "", { "os": "darwin", "cpu": "arm64" }, "sha512-5afxvwszzdulsU2w8JKWwY8/sJOLPzf0e1bFuvcW5h9zsEg+RQAojdW0ux2zyYAz7R8HvvzKCjLNJhVq965U7w=="], + + "@rollup/rollup-darwin-x64": ["@rollup/rollup-darwin-x64@4.41.1", "", { "os": "darwin", "cpu": "x64" }, "sha512-egpJACny8QOdHNNMZKf8xY0Is6gIMz+tuqXlusxquWu3F833DcMwmGM7WlvCO9sB3OsPjdC4U0wHw5FabzCGZg=="], + + "@rollup/rollup-freebsd-arm64": ["@rollup/rollup-freebsd-arm64@4.41.1", "", { "os": "freebsd", "cpu": "arm64" }, "sha512-DBVMZH5vbjgRk3r0OzgjS38z+atlupJ7xfKIDJdZZL6sM6wjfDNo64aowcLPKIx7LMQi8vybB56uh1Ftck/Atg=="], + + "@rollup/rollup-freebsd-x64": ["@rollup/rollup-freebsd-x64@4.41.1", "", { "os": "freebsd", "cpu": "x64" }, "sha512-3FkydeohozEskBxNWEIbPfOE0aqQgB6ttTkJ159uWOFn42VLyfAiyD9UK5mhu+ItWzft60DycIN1Xdgiy8o/SA=="], + + "@rollup/rollup-linux-arm-gnueabihf": ["@rollup/rollup-linux-arm-gnueabihf@4.41.1", "", { "os": "linux", "cpu": "arm" }, "sha512-wC53ZNDgt0pqx5xCAgNunkTzFE8GTgdZ9EwYGVcg+jEjJdZGtq9xPjDnFgfFozQI/Xm1mh+D9YlYtl+ueswNEg=="], + + "@rollup/rollup-linux-arm-musleabihf": ["@rollup/rollup-linux-arm-musleabihf@4.41.1", "", { "os": "linux", "cpu": "arm" }, "sha512-jwKCca1gbZkZLhLRtsrka5N8sFAaxrGz/7wRJ8Wwvq3jug7toO21vWlViihG85ei7uJTpzbXZRcORotE+xyrLA=="], + + "@rollup/rollup-linux-arm64-gnu": ["@rollup/rollup-linux-arm64-gnu@4.41.1", "", { "os": "linux", "cpu": "arm64" }, "sha512-g0UBcNknsmmNQ8V2d/zD2P7WWfJKU0F1nu0k5pW4rvdb+BIqMm8ToluW/eeRmxCared5dD76lS04uL4UaNgpNA=="], + + "@rollup/rollup-linux-arm64-musl": ["@rollup/rollup-linux-arm64-musl@4.41.1", "", { "os": "linux", "cpu": "arm64" }, "sha512-XZpeGB5TKEZWzIrj7sXr+BEaSgo/ma/kCgrZgL0oo5qdB1JlTzIYQKel/RmhT6vMAvOdM2teYlAaOGJpJ9lahg=="], + + "@rollup/rollup-linux-loongarch64-gnu": ["@rollup/rollup-linux-loongarch64-gnu@4.41.1", "", { "os": "linux", "cpu": "none" }, "sha512-bkCfDJ4qzWfFRCNt5RVV4DOw6KEgFTUZi2r2RuYhGWC8WhCA8lCAJhDeAmrM/fdiAH54m0mA0Vk2FGRPyzI+tw=="], + + "@rollup/rollup-linux-powerpc64le-gnu": ["@rollup/rollup-linux-powerpc64le-gnu@4.41.1", "", { "os": "linux", "cpu": "ppc64" }, "sha512-3mr3Xm+gvMX+/8EKogIZSIEF0WUu0HL9di+YWlJpO8CQBnoLAEL/roTCxuLncEdgcfJcvA4UMOf+2dnjl4Ut1A=="], + + "@rollup/rollup-linux-riscv64-gnu": ["@rollup/rollup-linux-riscv64-gnu@4.41.1", "", { "os": "linux", "cpu": "none" }, "sha512-3rwCIh6MQ1LGrvKJitQjZFuQnT2wxfU+ivhNBzmxXTXPllewOF7JR1s2vMX/tWtUYFgphygxjqMl76q4aMotGw=="], + + "@rollup/rollup-linux-riscv64-musl": ["@rollup/rollup-linux-riscv64-musl@4.41.1", "", { "os": "linux", "cpu": "none" }, "sha512-LdIUOb3gvfmpkgFZuccNa2uYiqtgZAz3PTzjuM5bH3nvuy9ty6RGc/Q0+HDFrHrizJGVpjnTZ1yS5TNNjFlklw=="], + + "@rollup/rollup-linux-s390x-gnu": ["@rollup/rollup-linux-s390x-gnu@4.41.1", "", { "os": "linux", "cpu": "s390x" }, "sha512-oIE6M8WC9ma6xYqjvPhzZYk6NbobIURvP/lEbh7FWplcMO6gn7MM2yHKA1eC/GvYwzNKK/1LYgqzdkZ8YFxR8g=="], + + "@rollup/rollup-linux-x64-gnu": ["@rollup/rollup-linux-x64-gnu@4.41.1", "", { "os": "linux", "cpu": "x64" }, "sha512-cWBOvayNvA+SyeQMp79BHPK8ws6sHSsYnK5zDcsC3Hsxr1dgTABKjMnMslPq1DvZIp6uO7kIWhiGwaTdR4Og9A=="], + + "@rollup/rollup-linux-x64-musl": ["@rollup/rollup-linux-x64-musl@4.41.1", "", { "os": "linux", "cpu": "x64" }, "sha512-y5CbN44M+pUCdGDlZFzGGBSKCA4A/J2ZH4edTYSSxFg7ce1Xt3GtydbVKWLlzL+INfFIZAEg1ZV6hh9+QQf9YQ=="], + + "@rollup/rollup-win32-arm64-msvc": ["@rollup/rollup-win32-arm64-msvc@4.41.1", "", { "os": "win32", "cpu": "arm64" }, "sha512-lZkCxIrjlJlMt1dLO/FbpZbzt6J/A8p4DnqzSa4PWqPEUUUnzXLeki/iyPLfV0BmHItlYgHUqJe+3KiyydmiNQ=="], + + "@rollup/rollup-win32-ia32-msvc": ["@rollup/rollup-win32-ia32-msvc@4.41.1", "", { "os": "win32", "cpu": "ia32" }, "sha512-+psFT9+pIh2iuGsxFYYa/LhS5MFKmuivRsx9iPJWNSGbh2XVEjk90fmpUEjCnILPEPJnikAU6SFDiEUyOv90Pg=="], + + "@rollup/rollup-win32-x64-msvc": ["@rollup/rollup-win32-x64-msvc@4.41.1", "", { "os": "win32", "cpu": "x64" }, "sha512-Wq2zpapRYLfi4aKxf2Xff0tN+7slj2d4R87WEzqw7ZLsVvO5zwYCIuEGSZYiK41+GlwUo1HiR+GdkLEJnCKTCw=="], + + "@types/estree": ["@types/estree@1.0.7", "", {}, "sha512-w28IoSUCJpidD/TGviZwwMJckNESJZXFu7NBZ5YJ4mEUnNraUn9Pm8HSZm/jDF1pDWYKspWE7oVphigUPRakIQ=="], + + "@types/json-schema": ["@types/json-schema@7.0.15", "", {}, "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA=="], + + "@types/node": ["@types/node@22.15.23", "", { "dependencies": { "undici-types": "~6.21.0" } }, "sha512-7Ec1zaFPF4RJ0eXu1YT/xgiebqwqoJz8rYPDi/O2BcZ++Wpt0Kq9cl0eg6NN6bYbPnR67ZLo7St5Q3UK0SnARw=="], + + "acorn": ["acorn@8.14.1", "", { "bin": "bin/acorn" }, "sha512-OvQ/2pUDKmgfCg++xsTX1wGxfTaszcHVcTctW4UJB4hibJx2HXxxO5UmVgyjMa+ZDsiaf5wWLXYpRWMmBI0QHg=="], + + "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=="], + + "ansi-regex": ["ansi-regex@6.1.0", "", {}, "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA=="], + + "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=="], + + "argparse": ["argparse@2.0.1", "", {}, "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q=="], + + "balanced-match": ["balanced-match@1.0.2", "", {}, "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="], + + "brace-expansion": ["brace-expansion@1.1.11", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA=="], + + "bundle-require": ["bundle-require@5.1.0", "", { "dependencies": { "load-tsconfig": "^0.2.3" }, "peerDependencies": { "esbuild": ">=0.18" } }, "sha512-3WrrOuZiyaaZPWiEt4G3+IffISVC9HYlWueJEBWED4ZH4aIAC2PnkdnuRrR94M+w6yGWn4AglWtJtBI8YqvgoA=="], + + "cac": ["cac@6.7.14", "", {}, "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ=="], + + "callsites": ["callsites@3.1.0", "", {}, "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ=="], + + "chalk": ["chalk@4.1.2", "", { "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" } }, "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA=="], + + "change-case": ["change-case@5.4.4", "", {}, "sha512-HRQyTk2/YPEkt9TnUPbOpr64Uw3KOicFWPVBb+xiHvd6eBx/qPr9xqfBFDT8P2vWsvvz4jbEkfDe71W3VyNu2w=="], + + "chokidar": ["chokidar@4.0.3", "", { "dependencies": { "readdirp": "^4.0.1" } }, "sha512-Qgzu8kfBvo+cA4962jnP1KkS6Dop5NS6g7R5LFYJr4b8Ub94PPQXUksCw9PvXoeXPRRddRNC5C1JQUR2SMGtnA=="], + + "color-convert": ["color-convert@2.0.1", "", { "dependencies": { "color-name": "~1.1.4" } }, "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ=="], + + "color-name": ["color-name@1.1.4", "", {}, "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="], + + "commander": ["commander@4.1.1", "", {}, "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA=="], + + "concat-map": ["concat-map@0.0.1", "", {}, "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="], + + "confbox": ["confbox@0.1.8", "", {}, "sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w=="], + + "consola": ["consola@3.4.2", "", {}, "sha512-5IKcdX0nnYavi6G7TtOhwkYzyjfJlatbjMjuLSfE2kYT5pMDOilZ4OvMhi637CcDICTmz3wARPoyhqyX1Y+XvA=="], + + "cross-spawn": ["cross-spawn@7.0.6", "", { "dependencies": { "path-key": "^3.1.0", "shebang-command": "^2.0.0", "which": "^2.0.1" } }, "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA=="], + + "csv-parser": ["csv-parser@3.2.0", "", { "bin": { "csv-parser": "bin/csv-parser" } }, "sha512-fgKbp+AJbn1h2dcAHKIdKNSSjfp43BZZykXsCjzALjKy80VXQNHPFJ6T9Afwdzoj24aMkq8GwDS7KGcDPpejrA=="], + + "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=="], + + "eastasianwidth": ["eastasianwidth@0.2.0", "", {}, "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA=="], + + "emoji-regex": ["emoji-regex@9.2.2", "", {}, "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg=="], + + "esbuild": ["esbuild@0.25.5", "", { "optionalDependencies": { "@esbuild/aix-ppc64": "0.25.5", "@esbuild/android-arm": "0.25.5", "@esbuild/android-arm64": "0.25.5", "@esbuild/android-x64": "0.25.5", "@esbuild/darwin-arm64": "0.25.5", "@esbuild/darwin-x64": "0.25.5", "@esbuild/freebsd-arm64": "0.25.5", "@esbuild/freebsd-x64": "0.25.5", "@esbuild/linux-arm": "0.25.5", "@esbuild/linux-arm64": "0.25.5", "@esbuild/linux-ia32": "0.25.5", "@esbuild/linux-loong64": "0.25.5", "@esbuild/linux-mips64el": "0.25.5", "@esbuild/linux-ppc64": "0.25.5", "@esbuild/linux-riscv64": "0.25.5", "@esbuild/linux-s390x": "0.25.5", "@esbuild/linux-x64": "0.25.5", "@esbuild/netbsd-arm64": "0.25.5", "@esbuild/netbsd-x64": "0.25.5", "@esbuild/openbsd-arm64": "0.25.5", "@esbuild/openbsd-x64": "0.25.5", "@esbuild/sunos-x64": "0.25.5", "@esbuild/win32-arm64": "0.25.5", "@esbuild/win32-ia32": "0.25.5", "@esbuild/win32-x64": "0.25.5" }, "bin": "bin/esbuild" }, "sha512-P8OtKZRv/5J5hhz0cUAdu/cLuPIKXpQl1R9pZtvmHWQvrAUVd0UNIPT4IB4W3rNOqVO0rlqHmCIbSwxh/c9yUQ=="], + + "escape-string-regexp": ["escape-string-regexp@4.0.0", "", {}, "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA=="], + + "eslint": ["eslint@9.27.0", "", { "dependencies": { "@eslint-community/eslint-utils": "^4.2.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.20.0", "@eslint/config-helpers": "^0.2.1", "@eslint/core": "^0.14.0", "@eslint/eslintrc": "^3.3.1", "@eslint/js": "9.27.0", "@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.3.0", "eslint-visitor-keys": "^4.2.0", "espree": "^10.3.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": "bin/eslint.js" }, "sha512-ixRawFQuMB9DZ7fjU3iGGganFDp3+45bPOdaRurcFHSXO1e/sYwUX/FtQZpLZJR6SjMoJH8hR2pPEAfDyCoU2Q=="], + + "eslint-scope": ["eslint-scope@8.3.0", "", { "dependencies": { "esrecurse": "^4.3.0", "estraverse": "^5.2.0" } }, "sha512-pUNxi75F8MJ/GdeKtVLSbYg4ZI34J6C0C7sbL4YOp2exGwen7ZsuBqKzUhXd0qMQ362yET3z+uPwKeg/0C2XCQ=="], + + "eslint-visitor-keys": ["eslint-visitor-keys@4.2.0", "", {}, "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw=="], + + "espree": ["espree@10.3.0", "", { "dependencies": { "acorn": "^8.14.0", "acorn-jsx": "^5.3.2", "eslint-visitor-keys": "^4.2.0" } }, "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg=="], + + "esquery": ["esquery@1.6.0", "", { "dependencies": { "estraverse": "^5.1.0" } }, "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg=="], + + "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-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=="], + + "fdir": ["fdir@6.4.5", "", { "peerDependencies": { "picomatch": "^3 || ^4" } }, "sha512-4BG7puHpVsIYxZUbiUE3RqGloLaSSwzYie5jvasC4LWuBWzZawynvYouhjbQKw2JuIGYdm0DzIxl8iVidKlUEw=="], + + "file-entry-cache": ["file-entry-cache@8.0.0", "", { "dependencies": { "flat-cache": "^4.0.0" } }, "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ=="], + + "find-up": ["find-up@5.0.0", "", { "dependencies": { "locate-path": "^6.0.0", "path-exists": "^4.0.0" } }, "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng=="], + + "fix-dts-default-cjs-exports": ["fix-dts-default-cjs-exports@1.0.1", "", { "dependencies": { "magic-string": "^0.30.17", "mlly": "^1.7.4", "rollup": "^4.34.8" } }, "sha512-pVIECanWFC61Hzl2+oOCtoJ3F17kglZC/6N94eRWycFgBH35hHx0Li604ZIzhseh97mf2p0cv7vVrOZGoqhlEg=="], + + "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=="], + + "fsevents": ["fsevents@2.3.3", "", { "os": "darwin" }, "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw=="], + + "glob": ["glob@10.4.5", "", { "dependencies": { "foreground-child": "^3.1.0", "jackspeak": "^3.1.2", "minimatch": "^9.0.4", "minipass": "^7.1.2", "package-json-from-dist": "^1.0.0", "path-scurry": "^1.11.1" }, "bin": "dist/esm/bin.mjs" }, "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg=="], + + "glob-parent": ["glob-parent@6.0.2", "", { "dependencies": { "is-glob": "^4.0.3" } }, "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A=="], + + "globals": ["globals@14.0.0", "", {}, "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ=="], + + "has-flag": ["has-flag@4.0.0", "", {}, "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ=="], + + "ignore": ["ignore@5.3.2", "", {}, "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g=="], + + "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=="], + + "is-extglob": ["is-extglob@2.1.1", "", {}, "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ=="], + + "is-fullwidth-code-point": ["is-fullwidth-code-point@3.0.0", "", {}, "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg=="], + + "is-glob": ["is-glob@4.0.3", "", { "dependencies": { "is-extglob": "^2.1.1" } }, "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg=="], + + "isexe": ["isexe@2.0.0", "", {}, "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw=="], + + "jackspeak": ["jackspeak@3.4.3", "", { "dependencies": { "@isaacs/cliui": "^8.0.2" }, "optionalDependencies": { "@pkgjs/parseargs": "^0.11.0" } }, "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw=="], + + "joycon": ["joycon@3.1.1", "", {}, "sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw=="], + + "js-yaml": ["js-yaml@4.1.0", "", { "dependencies": { "argparse": "^2.0.1" }, "bin": "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=="], + + "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=="], + + "load-tsconfig": ["load-tsconfig@0.2.5", "", {}, "sha512-IXO6OCs9yg8tMKzfPZ1YmheJbZCiEsnBdcB03l0OcfK9prKnJb96siuHCr5Fl37/yo9DnKU+TLpxzTUspw9shg=="], + + "locate-path": ["locate-path@6.0.0", "", { "dependencies": { "p-locate": "^5.0.0" } }, "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw=="], + + "lodash.merge": ["lodash.merge@4.6.2", "", {}, "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ=="], + + "lodash.sortby": ["lodash.sortby@4.7.0", "", {}, "sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA=="], + + "lru-cache": ["lru-cache@10.4.3", "", {}, "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ=="], + + "magic-string": ["magic-string@0.30.17", "", { "dependencies": { "@jridgewell/sourcemap-codec": "^1.5.0" } }, "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA=="], + + "minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], + + "minipass": ["minipass@7.1.2", "", {}, "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw=="], + + "mlly": ["mlly@1.7.4", "", { "dependencies": { "acorn": "^8.14.0", "pathe": "^2.0.1", "pkg-types": "^1.3.0", "ufo": "^1.5.4" } }, "sha512-qmdSIPC4bDJXgZTCR7XosJiNKySV7O215tsPtDN9iEO/7q/76b/ijtgRu/+epFXSJhijtTCCGp3DWS549P3xKw=="], + + "ms": ["ms@2.1.3", "", {}, "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="], + + "mz": ["mz@2.7.0", "", { "dependencies": { "any-promise": "^1.0.0", "object-assign": "^4.0.1", "thenify-all": "^1.0.0" } }, "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q=="], + + "natural-compare": ["natural-compare@1.4.0", "", {}, "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw=="], + + "object-assign": ["object-assign@4.1.1", "", {}, "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg=="], + + "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=="], + + "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-scurry": ["path-scurry@1.11.1", "", { "dependencies": { "lru-cache": "^10.2.0", "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" } }, "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA=="], + + "pathe": ["pathe@2.0.3", "", {}, "sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w=="], + + "picocolors": ["picocolors@1.1.1", "", {}, "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA=="], + + "picomatch": ["picomatch@4.0.2", "", {}, "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg=="], + + "pirates": ["pirates@4.0.7", "", {}, "sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA=="], + + "pkg-types": ["pkg-types@1.3.1", "", { "dependencies": { "confbox": "^0.1.8", "mlly": "^1.7.4", "pathe": "^2.0.1" } }, "sha512-/Jm5M4RvtBFVkKWRu2BLUTNP8/M2a+UwuAX+ae4770q1qVGtfjG+WTCupoZixokjmHiry8uI+dlY8KXYV5HVVQ=="], + + "postcss-load-config": ["postcss-load-config@6.0.1", "", { "dependencies": { "lilconfig": "^3.1.1" }, "peerDependencies": { "jiti": ">=1.21.0", "postcss": ">=8.0.9", "tsx": "^4.8.1", "yaml": "^2.4.2" }, "optionalPeers": ["jiti", "postcss", "tsx", "yaml"] }, "sha512-oPtTM4oerL+UXmx+93ytZVN82RrlY/wPUV8IeDxFrzIjXOLF1pN+EmKPLbubvKHT2HC20xXsCAH2Z+CKV6Oz/g=="], + + "prelude-ls": ["prelude-ls@1.2.1", "", {}, "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g=="], + + "prettier": ["prettier@3.5.3", "", { "bin": "bin/prettier.cjs" }, "sha512-QQtaxnoDJeAkDvDKWCLiwIXkTgRhwYDEQCghU9Z6q03iyek/rxRh/2lC3HB7P8sWT2xC/y5JDctPLBIGzHKbhw=="], + + "punycode": ["punycode@2.3.1", "", {}, "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg=="], + + "readdirp": ["readdirp@4.1.2", "", {}, "sha512-GDhwkLfywWL2s6vEjyhri+eXmfH6j1L7JE27WhqLeYzoh/A3DBaYGEj2H/HFZCn/kMfim73FXxEJTw06WtxQwg=="], + + "resolve-from": ["resolve-from@5.0.0", "", {}, "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw=="], + + "rollup": ["rollup@4.41.1", "", { "dependencies": { "@types/estree": "1.0.7" }, "optionalDependencies": { "@rollup/rollup-android-arm-eabi": "4.41.1", "@rollup/rollup-android-arm64": "4.41.1", "@rollup/rollup-darwin-arm64": "4.41.1", "@rollup/rollup-darwin-x64": "4.41.1", "@rollup/rollup-freebsd-arm64": "4.41.1", "@rollup/rollup-freebsd-x64": "4.41.1", "@rollup/rollup-linux-arm-gnueabihf": "4.41.1", "@rollup/rollup-linux-arm-musleabihf": "4.41.1", "@rollup/rollup-linux-arm64-gnu": "4.41.1", "@rollup/rollup-linux-arm64-musl": "4.41.1", "@rollup/rollup-linux-loongarch64-gnu": "4.41.1", "@rollup/rollup-linux-powerpc64le-gnu": "4.41.1", "@rollup/rollup-linux-riscv64-gnu": "4.41.1", "@rollup/rollup-linux-riscv64-musl": "4.41.1", "@rollup/rollup-linux-s390x-gnu": "4.41.1", "@rollup/rollup-linux-x64-gnu": "4.41.1", "@rollup/rollup-linux-x64-musl": "4.41.1", "@rollup/rollup-win32-arm64-msvc": "4.41.1", "@rollup/rollup-win32-ia32-msvc": "4.41.1", "@rollup/rollup-win32-x64-msvc": "4.41.1", "fsevents": "~2.3.2" }, "bin": "dist/bin/rollup" }, "sha512-cPmwD3FnFv8rKMBc1MxWCwVQFxwf1JEmSX3iQXrRVVG15zerAIXRjMFVWnd5Q5QvgKF7Aj+5ykXFhUl+QGnyOw=="], + + "shebang-command": ["shebang-command@2.0.0", "", { "dependencies": { "shebang-regex": "^3.0.0" } }, "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA=="], + + "shebang-regex": ["shebang-regex@3.0.0", "", {}, "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A=="], + + "signal-exit": ["signal-exit@4.1.0", "", {}, "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw=="], + + "source-map": ["source-map@0.8.0-beta.0", "", { "dependencies": { "whatwg-url": "^7.0.0" } }, "sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA=="], + + "string-width": ["string-width@5.1.2", "", { "dependencies": { "eastasianwidth": "^0.2.0", "emoji-regex": "^9.2.2", "strip-ansi": "^7.0.1" } }, "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA=="], + + "string-width-cjs": ["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=="], + + "strip-ansi": ["strip-ansi@7.1.0", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ=="], + + "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=="], + + "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=="], + + "supports-color": ["supports-color@7.2.0", "", { "dependencies": { "has-flag": "^4.0.0" } }, "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw=="], + + "thenify": ["thenify@3.3.1", "", { "dependencies": { "any-promise": "^1.0.0" } }, "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw=="], + + "thenify-all": ["thenify-all@1.6.0", "", { "dependencies": { "thenify": ">= 3.1.0 < 4" } }, "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA=="], + + "tinyexec": ["tinyexec@0.3.2", "", {}, "sha512-KQQR9yN7R5+OSwaK0XQoj22pwHoTlgYqmUscPYoknOoWCWfj/5/ABTMRi69FrKU5ffPVh5QcFikpWJI/P1ocHA=="], + + "tinyglobby": ["tinyglobby@0.2.14", "", { "dependencies": { "fdir": "^6.4.4", "picomatch": "^4.0.2" } }, "sha512-tX5e7OM1HnYr2+a2C/4V0htOcSQcoSTH9KgJnVvNm5zm/cyEWKJ7j7YutsH9CxMdtOkkLFy2AHrMci9IM8IPZQ=="], + + "tr46": ["tr46@1.0.1", "", { "dependencies": { "punycode": "^2.1.0" } }, "sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA=="], + + "tree-kill": ["tree-kill@1.2.2", "", { "bin": "cli.js" }, "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A=="], + + "ts-interface-checker": ["ts-interface-checker@0.1.13", "", {}, "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA=="], + + "tsup": ["tsup@8.5.0", "", { "dependencies": { "bundle-require": "^5.1.0", "cac": "^6.7.14", "chokidar": "^4.0.3", "consola": "^3.4.0", "debug": "^4.4.0", "esbuild": "^0.25.0", "fix-dts-default-cjs-exports": "^1.0.0", "joycon": "^3.1.1", "picocolors": "^1.1.1", "postcss-load-config": "^6.0.1", "resolve-from": "^5.0.0", "rollup": "^4.34.8", "source-map": "0.8.0-beta.0", "sucrase": "^3.35.0", "tinyexec": "^0.3.2", "tinyglobby": "^0.2.11", "tree-kill": "^1.2.2" }, "peerDependencies": { "@microsoft/api-extractor": "^7.36.0", "@swc/core": "^1", "postcss": "^8.4.12", "typescript": ">=4.5.0" }, "optionalPeers": ["@microsoft/api-extractor", "@swc/core", "postcss", "typescript"], "bin": { "tsup": "dist/cli-default.js", "tsup-node": "dist/cli-node.js" } }, "sha512-VmBp77lWNQq6PfuMqCHD3xWl22vEoWsKajkF8t+yMBawlUS8JzEI+vOVMeuNZIuMML8qXRizFKi9oD5glKQVcQ=="], + + "turbo": ["turbo@2.5.3", "", { "optionalDependencies": { "turbo-darwin-64": "2.5.3", "turbo-darwin-arm64": "2.5.3", "turbo-linux-64": "2.5.3", "turbo-linux-arm64": "2.5.3", "turbo-windows-64": "2.5.3", "turbo-windows-arm64": "2.5.3" }, "bin": "bin/turbo" }, "sha512-iHuaNcq5GZZnr3XDZNuu2LSyCzAOPwDuo5Qt+q64DfsTP1i3T2bKfxJhni2ZQxsvAoxRbuUK5QetJki4qc5aYA=="], + + "turbo-darwin-64": ["turbo-darwin-64@2.5.3", "", { "os": "darwin", "cpu": "x64" }, "sha512-YSItEVBUIvAGPUDpAB9etEmSqZI3T6BHrkBkeSErvICXn3dfqXUfeLx35LfptLDEbrzFUdwYFNmt8QXOwe9yaw=="], + + "turbo-darwin-arm64": ["turbo-darwin-arm64@2.5.3", "", { "os": "darwin", "cpu": "arm64" }, "sha512-5PefrwHd42UiZX7YA9m1LPW6x9YJBDErXmsegCkVp+GjmWrADfEOxpFrGQNonH3ZMj77WZB2PVE5Aw3gA+IOhg=="], + + "turbo-linux-64": ["turbo-linux-64@2.5.3", "", { "os": "linux", "cpu": "x64" }, "sha512-M9xigFgawn5ofTmRzvjjLj3Lqc05O8VHKuOlWNUlnHPUltFquyEeSkpQNkE/vpPdOR14AzxqHbhhxtfS4qvb1w=="], + + "turbo-linux-arm64": ["turbo-linux-arm64@2.5.3", "", { "os": "linux", "cpu": "arm64" }, "sha512-auJRbYZ8SGJVqvzTikpg1bsRAsiI9Tk0/SDkA5Xgg0GdiHDH/BOzv1ZjDE2mjmlrO/obr19Dw+39OlMhwLffrw=="], + + "turbo-windows-64": ["turbo-windows-64@2.5.3", "", { "os": "win32", "cpu": "x64" }, "sha512-arLQYohuHtIEKkmQSCU9vtrKUg+/1TTstWB9VYRSsz+khvg81eX6LYHtXJfH/dK7Ho6ck+JaEh5G+QrE1jEmCQ=="], + + "turbo-windows-arm64": ["turbo-windows-arm64@2.5.3", "", { "os": "win32", "cpu": "arm64" }, "sha512-3JPn66HAynJ0gtr6H+hjY4VHpu1RPKcEwGATvGUTmLmYSYBQieVlnGDRMMoYN066YfyPqnNGCfhYbXfH92Cm0g=="], + + "type-check": ["type-check@0.4.0", "", { "dependencies": { "prelude-ls": "^1.2.1" } }, "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew=="], + + "ufo": ["ufo@1.6.1", "", {}, "sha512-9a4/uxlTWJ4+a5i0ooc1rU7C7YOw3wT+UGqdeNNHWnOF9qcMBgLRS+4IYUqbczewFx4mLEig6gawh7X6mFlEkA=="], + + "undici-types": ["undici-types@6.21.0", "", {}, "sha512-iwDZqg0QAGrg9Rav5H4n0M64c3mkR59cJ6wQp+7C4nI0gsmExaedaYLNO44eT4AtBBwjbTiGPMlt2Md0T9H9JQ=="], + + "uri-js": ["uri-js@4.4.1", "", { "dependencies": { "punycode": "^2.1.0" } }, "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg=="], + + "webidl-conversions": ["webidl-conversions@4.0.2", "", {}, "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg=="], + + "whatwg-url": ["whatwg-url@7.1.0", "", { "dependencies": { "lodash.sortby": "^4.7.0", "tr46": "^1.0.1", "webidl-conversions": "^4.0.2" } }, "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg=="], + + "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=="], + + "yocto-queue": ["yocto-queue@0.1.0", "", {}, "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q=="], + + "@eslint-community/eslint-utils/eslint-visitor-keys": ["eslint-visitor-keys@3.4.3", "", {}, "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag=="], + + "@humanfs/node/@humanwhocodes/retry": ["@humanwhocodes/retry@0.3.1", "", {}, "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA=="], + + "glob/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + + "import-fresh/resolve-from": ["resolve-from@4.0.0", "", {}, "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g=="], + + "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=="], + + "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=="], + + "glob/minimatch/brace-expansion": ["brace-expansion@2.0.1", "", { "dependencies": { "balanced-match": "^1.0.0" } }, "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA=="], + + "string-width-cjs/strip-ansi/ansi-regex": ["ansi-regex@5.0.1", "", {}, "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ=="], + + "wrap-ansi-cjs/string-width/emoji-regex": ["emoji-regex@8.0.0", "", {}, "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A=="], + + "wrap-ansi-cjs/strip-ansi/ansi-regex": ["ansi-regex@5.0.1", "", {}, "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ=="], + } +} diff --git a/client/src/components/app.tsx b/client/src/components/app.tsx index 776882de..7100b55b 100644 --- a/client/src/components/app.tsx +++ b/client/src/components/app.tsx @@ -2,6 +2,7 @@ import { Games } from "@/components/games"; import { SceneLayout } from "@/components/scenes/layout"; import { GamePage } from "./pages/game"; import { useEffect } from "react"; +import { useLocation } from "react-router-dom"; import { PlayerPage } from "./pages/player"; import { cn } from "@cartridge/ui/utils"; import { useSidebar } from "@/hooks/sidebar"; @@ -13,11 +14,14 @@ import { useDevice } from "@/hooks/device"; import { MarketPage } from "./pages/market"; import { Filters } from "./filters"; import { UserCard } from "./user/user-card"; +import { PredictionPage } from "./pages/prediction"; +import { PredictionSidebar } from "./games/prediction-sidebar"; export function App() { const { isOpen, toggle, handleTouchMove, handleTouchStart } = useSidebar(); const { setPlayer } = useArcade(); - const { player, collection } = useProject(); + const { player, collection, tab } = useProject(); + const location = useLocation(); const { isPWA, isMobile } = useDevice(); @@ -51,7 +55,13 @@ export function App() {
{!isMobile && }
- {!collection ? : } + {tab && tab.startsWith("prediction") ? ( + + ) : !collection ? ( + + ) : ( + + )}
@@ -77,7 +87,10 @@ export function App() { "bg-background-125 shadow-[0px_0px_8px_0px_rgba(15,20,16,_0.50)]", )} > - {!player ? ( + {location.pathname.includes("/prediction") || + (tab && tab.startsWith("prediction-")) ? ( + + ) : !player ? ( !collection ? ( ) : ( diff --git a/client/src/components/games/index.tsx b/client/src/components/games/index.tsx index c8a03e77..62fcffe1 100644 --- a/client/src/components/games/index.tsx +++ b/client/src/components/games/index.tsx @@ -203,6 +203,7 @@ export const Game = ({ const gameName = `${game?.name.toLowerCase().replace(/ /g, "-") || id}`; pathname = pathname.replace(/\/game\/[^/]+/, ""); pathname = pathname.replace(/\/edition\/[^/]+/, ""); + pathname = pathname.replace(/\/prediction$/, ""); if (id !== 0) pathname = joinPaths(`/game/${gameName}`, pathname); navigate(pathname || "/"); // Close sidebar on mobile when a game is selected diff --git a/client/src/components/games/prediction-sidebar.tsx b/client/src/components/games/prediction-sidebar.tsx new file mode 100644 index 00000000..3fb01467 --- /dev/null +++ b/client/src/components/games/prediction-sidebar.tsx @@ -0,0 +1,128 @@ +import { useDevice } from "@/hooks/device"; +import { useSidebar } from "@/hooks/sidebar"; +import { + Button, + Card, + CardContent, + CardHeader, + CardTitle, + cn, + Thumbnail, +} from "@cartridge/ui"; + +export const PredictionSidebar = () => { + const { isMobile } = useDevice(); + const { isOpen, handleTouchStart, handleTouchMove } = useSidebar(); + + return ( +
+ + + + Vault Details + + + +
+
+ +

+ 8,800 +

+
+

+ Vault Total +

+
+
+
+
+ +

+ 2,200 +

+
+

+ Your Stake +

+
+
+
+ +

+ 34 +

+
+

+ Fees Earned +

+
+
+
+
+ + + + Market Fees + + + +
+

Protocol

+

0.3%

+
+
+

Oracle

+

0.5%

+
+
+

Creator

+

4.2%

+
+
+

Vault

+

1.39%

+
+
+
+ + + +
+ ); +}; diff --git a/client/src/components/modules/tab.tsx b/client/src/components/modules/tab.tsx index 1f26b59e..6155cecf 100644 --- a/client/src/components/modules/tab.tsx +++ b/client/src/components/modules/tab.tsx @@ -27,12 +27,24 @@ export interface ArcadeTabProps extends VariantProps { label: string; active?: boolean; className?: string; + badge?: number; onClick?: () => void; } export const ArcadeTab = React.forwardRef( ( - { Icon, value, label, active, className, variant, size, onClick, ...props }, + { + Icon, + value, + label, + active, + className, + variant, + size, + onClick, + badge, + ...props + }, ref, ) => { return ( @@ -52,6 +64,20 @@ export const ArcadeTab = React.forwardRef( > {Icon}

{label}

+ {badge && ( +
+ + {badge.toLocaleString()} + +
+ )}
, @@ -81,6 +85,10 @@ export const ArcadeTabs = ({ "guilds", "items", "holders", + "prediction-activity", + "prediction-holders", + "prediction-comments", + "prediction-positions", ], onTabClick, variant, @@ -105,7 +113,12 @@ export const ArcadeTabs = ({ const tabWidths = new Map(); hiddenRef.current.childNodes.forEach((node) => { const element = node as HTMLDivElement; - const tab = element.textContent?.toLowerCase(); + const tabElement = + element.getAttribute("aria-controls")?.split("-") || []; + tabElement.splice(0, 3); + + const tab = tabElement.join("-"); + if (tab) { const visible = order.includes(tab as TabValue); tabWidths.set(tab as TabValue, { width: element.offsetWidth, visible }); @@ -297,6 +310,14 @@ const Tab = ({ return ; case "positions": return ; + case "prediction-activity": + return ; + case "prediction-holders": + return ; + case "prediction-comments": + return ; + case "prediction-positions": + return ; default: return null; } @@ -842,4 +863,186 @@ const PositionsNavButton = React.forwardRef( }, ); +const PredictionActivityNavButton = React.forwardRef< + HTMLButtonElement, + NavButtonProps +>(({ value, active, size, onClick, item, isMobile }, ref) => { + if (isMobile) { + return ( + + + + + + ); + } + + if (item) { + return ( + } + label="Activity" + active={active} + size={size} + onClick={onClick} + /> + ); + } + + return ( + } + label="Activity" + active={active} + size={size} + onClick={onClick} + /> + ); +}); + +const PredictionHoldersNavButton = React.forwardRef< + HTMLButtonElement, + NavButtonProps +>(({ value, active, size, onClick, item, isMobile }, ref) => { + if (isMobile) { + return ( + + + + + + ); + } + + if (item) { + return ( + } + label="Holders" + active={active} + size={size} + onClick={onClick} + /> + ); + } + + return ( + } + label="Holders" + active={active} + size={size} + onClick={onClick} + /> + ); +}); + +const PredictionCommentsNavButton = React.forwardRef< + HTMLButtonElement, + NavButtonProps +>(({ value, active, size, onClick, item, isMobile }, ref) => { + if (isMobile) { + return ( + + + + + + ); + } + + if (item) { + return ( + } + label="Comments" + active={active} + size={size} + onClick={onClick} + /> + ); + } + + return ( + } + label="Comments" + active={active} + size={size} + onClick={onClick} + badge={10} + /> + ); +}); + +const PredictionPositionsNavButton = React.forwardRef< + HTMLButtonElement, + NavButtonProps +>(({ value, active, size, onClick, item, isMobile }, ref) => { + if (isMobile) { + return ( + + + + + + ); + } + + if (item) { + return ( + } + label="My Positions" + active={active} + size={size} + onClick={onClick} + /> + ); + } + + return ( + } + label="My Positions" + active={active} + size={size} + onClick={onClick} + badge={2} + /> + ); +}); + export default ArcadeTabs; diff --git a/client/src/components/pages/game.tsx b/client/src/components/pages/game.tsx index f366933c..dd7c2c7f 100644 --- a/client/src/components/pages/game.tsx +++ b/client/src/components/pages/game.tsx @@ -1,11 +1,11 @@ import { useCallback, useMemo, useState } from "react"; -import { TabsContent, Thumbnail, Empty, TabValue } from "@cartridge/ui"; +import { TabsContent, Thumbnail, Empty } from "@cartridge/ui"; import { cn } from "@cartridge/ui/utils"; import { DiscoverScene } from "../scenes/discover"; import { LeaderboardScene } from "../scenes/leaderboard"; import { useLocation, useNavigate } from "react-router-dom"; import { Socials } from "@cartridge/arcade"; -import { ArcadeTabs } from "../modules"; +import { ArcadeTabs, TabValue } from "../modules"; import { MarketplaceScene } from "../scenes/marketplace"; import { GuildsScene } from "../scenes/guild"; import { AboutScene } from "../scenes/about"; @@ -29,26 +29,31 @@ export function GamePage() { const handleClick = useCallback( (value: string) => { let pathname = location.pathname; - pathname = pathname.replace(/\/tab\/[^/]+/, ""); + pathname = pathname.replace(/\/tab\/.*$/, ""); pathname = joinPaths(pathname, `/tab/${value}`); navigate(pathname || "/"); }, [location, navigate], ); + const isPreview = useMemo(() => { + return window.location.href.toLowerCase().includes(".preview.cartridge.gg"); + }, []); + const order: TabValue[] = useMemo(() => { const tabs: TabValue[] = game ? ["activity", "leaderboard", "marketplace", "predict", "about"] : ["activity", "leaderboard", "marketplace", "predict"]; - if (process.env.NODE_ENV !== "development") { + // not in dev AND not preview deployments + if (process.env.NODE_ENV !== "development" && !isPreview) { // Remove predict tab in production for now const predictIndex = tabs.indexOf("predict"); tabs.splice(predictIndex, 1); } return tabs; - }, [game]); + }, [game, isPreview]); const defaultValue = useMemo(() => { if (!order.includes(tab as TabValue)) return "activity"; diff --git a/client/src/components/pages/market.tsx b/client/src/components/pages/market.tsx index 9b901b9b..74699afb 100644 --- a/client/src/components/pages/market.tsx +++ b/client/src/components/pages/market.tsx @@ -6,12 +6,11 @@ import { Button, cn, TabsContent, - TabValue, Thumbnail, TimesIcon, VerifiedIcon, } from "@cartridge/ui"; -import { ArcadeTabs } from "../modules"; +import { ArcadeTabs, TabValue } from "../modules"; import { useLocation, useNavigate } from "react-router-dom"; import { useProject } from "@/hooks/project"; import { joinPaths } from "@/helpers"; @@ -40,7 +39,7 @@ export function MarketPage() { const handleClick = useCallback( (value: string) => { let pathname = location.pathname; - pathname = pathname.replace(/\/tab\/[^/]+/, ""); + pathname = pathname.replace(/\/tab\/.*$/, ""); pathname = joinPaths(pathname, `/tab/${value}`); navigate(pathname || "/"); }, diff --git a/client/src/components/pages/player.tsx b/client/src/components/pages/player.tsx index 04adbe97..3ba029dd 100644 --- a/client/src/components/pages/player.tsx +++ b/client/src/components/pages/player.tsx @@ -6,13 +6,12 @@ import { Button, cn, TabsContent, - TabValue, TimesIcon, UserAddIcon, UserCheckIcon, } from "@cartridge/ui"; import { ActivityScene } from "../scenes/activity"; -import { ArcadeTabs } from "../modules"; +import { ArcadeTabs, TabValue } from "../modules"; import { useLocation, useNavigate } from "react-router-dom"; import { useUsername, useUsernames } from "@/hooks/account"; import { useAddress } from "@/hooks/address"; @@ -34,6 +33,12 @@ export function PlayerPage() { const { account, connector, isConnected } = useAccount(); const { provider, follows } = useArcade(); const { edition, tab } = useProject(); + const location = useLocation(); + const navigate = useNavigate(); + + const isPreview = useMemo(() => { + return window.location.href.toLowerCase().includes(".preview.cartridge.gg"); + }, []); const order: TabValue[] = useMemo(() => { const order = [ @@ -43,26 +48,25 @@ export function PlayerPage() { "positions", ] as TabValue[]; - if (process.env.NODE_ENV !== "development") { + // not in dev AND not preview deployments + if (process.env.NODE_ENV !== "development" && !isPreview) { // Remove predict tab in production for now const predictIndex = order.indexOf("positions"); order.splice(predictIndex, 1); } return order; - }, []); + }, [isPreview]); const defaultValue = useMemo(() => { if (!order.includes(tab as TabValue)) return "inventory"; return tab; }, [tab, order]); - const location = useLocation(); - const navigate = useNavigate(); const handleClick = useCallback( (value: string) => { let pathname = location.pathname; - pathname = pathname.replace(/\/tab\/[^/]+/, ""); + pathname = pathname.replace(/\/tab\/.*$/, ""); pathname = joinPaths(pathname, `/tab/${value}`); navigate(pathname || "/"); }, @@ -72,7 +76,7 @@ export function PlayerPage() { const handleClose = useCallback(() => { let pathname = location.pathname; pathname = pathname.replace(/\/player\/[^/]+/, ""); - pathname = pathname.replace(/\/tab\/[^/]+/, ""); + pathname = pathname.replace(/\/tab\/.*$/, ""); navigate(pathname || "/"); }, [location, navigate]); diff --git a/client/src/components/pages/prediction.tsx b/client/src/components/pages/prediction.tsx new file mode 100644 index 00000000..7b025b1b --- /dev/null +++ b/client/src/components/pages/prediction.tsx @@ -0,0 +1,72 @@ +import { cn } from "@cartridge/ui"; +import { BuySection, MarketChart, PredictionTabs } from "../prediction"; +import { useLocation, useNavigate } from "react-router-dom"; +import { useCallback, useMemo } from "react"; +import { joinPaths } from "@/helpers"; +import { TabValue } from "../modules"; +import { PredictionHeader } from "../prediction/header"; + +export interface Player { + name: string; + color: string; + baseValue: number; // Base percentage value around which to randomize + variance: number; // Amount of randomization (+/-) +} + +export interface PredictionPageProps { + players?: Player[]; +} + +export function PredictionPage({ players }: PredictionPageProps) { + const location = useLocation(); + const navigate = useNavigate(); + + const handleTabClick = useCallback( + (value: string) => { + let pathname = location.pathname; + pathname = pathname.replace(/\/tab\/.*$/, ""); + pathname = joinPaths(pathname, `/tab/${value}`); + navigate(pathname || "/"); + }, + [location, navigate], + ); + + const defaultValue = useMemo(() => { + const pathname = location.pathname; + const tabMatch = pathname.match(/\/tab\/([^/]+)/); + if (tabMatch) { + const tab = tabMatch[1] as TabValue; + if ( + [ + "prediction-activity", + "prediction-holders", + "prediction-comments", + "prediction-positions", + ].includes(tab) + ) { + return tab; + } + } + return "prediction-activity"; + }, [location]); + + return ( +
+
+ + + + + +
+ + +
+ ); +} diff --git a/client/src/components/predict/index.tsx b/client/src/components/predict/index.tsx index 45c489f7..87343176 100644 --- a/client/src/components/predict/index.tsx +++ b/client/src/components/predict/index.tsx @@ -16,7 +16,9 @@ export const Predict = () => { return (
{Array.from( - [1, 2, 3, 4].map((i) => ), + [1, 2, 3, 4].map((i) => ( + + )), )}
); diff --git a/client/src/components/predict/predict-card.tsx b/client/src/components/predict/predict-card.tsx index 56f57c76..0a95d4ec 100644 --- a/client/src/components/predict/predict-card.tsx +++ b/client/src/components/predict/predict-card.tsx @@ -8,6 +8,8 @@ import { Thumbnail, } from "@cartridge/ui"; import { UserAvatar } from "../user/avatar"; +import { useNavigate } from "react-router-dom"; +import { useProject } from "@/hooks/project"; export interface PredictCardProps { image: string; @@ -42,9 +44,21 @@ export const PredictCard = React.forwardRef< }, ref, ) => { + const navigate = useNavigate(); + const { game } = useProject(); + + const handleClick = () => { + if (!game) return navigate("/"); + + const gameName = game.name.toLowerCase().replace(/ /g, "-"); + const predictionPath = `/game/${gameName}/prediction/tab/prediction-activity`; + navigate(predictionPath); + }; + return ( diff --git a/client/src/components/prediction/activity-feed.tsx b/client/src/components/prediction/activity-feed.tsx new file mode 100644 index 00000000..33db7d11 --- /dev/null +++ b/client/src/components/prediction/activity-feed.tsx @@ -0,0 +1,61 @@ +import { cn } from "@cartridge/ui"; +import React, { HTMLAttributes } from "react"; +import { UserAvatar } from "../user/avatar"; + +interface Props extends HTMLAttributes { + username: string; + total: number; + itemName: string; + timestamp: string; +} + +export const PredictionActivityFeed = React.forwardRef( + ({ username, total, itemName, timestamp, className, ...props }, ref) => { + return ( +
+
+
+ +

{username}

+
+ + bought + +
+ +
+

{total}

+
+
+ + shares of + +
+ +
+

+ {itemName} +

+
+
+
+
+

+ {timestamp} +

+
+
+ ); + }, +); diff --git a/client/src/components/prediction/buy-card.tsx b/client/src/components/prediction/buy-card.tsx new file mode 100644 index 00000000..40b557ba --- /dev/null +++ b/client/src/components/prediction/buy-card.tsx @@ -0,0 +1,47 @@ +import { Button, cn, DoubleWedgeIcon, Thumbnail } from "@cartridge/ui"; +import { UserAvatar } from "../user/avatar"; +import React, { HTMLAttributes } from "react"; + +interface Props extends HTMLAttributes { + name: string; + percentage: string; + percentageChange: string; +} + +export const BuyCard = React.forwardRef( + ({ className, name, percentage, percentageChange }, ref) => { + return ( +
+
+ } + rounded + size="md" + variant="lighter" + /> +

{name}

+
+
+
+
+ +

{percentageChange}

+
+

+ {percentage} +

+
+ +
+
+ ); + }, +); diff --git a/client/src/components/prediction/buy-section.tsx b/client/src/components/prediction/buy-section.tsx new file mode 100644 index 00000000..5aa394c3 --- /dev/null +++ b/client/src/components/prediction/buy-section.tsx @@ -0,0 +1,47 @@ +import React, { HTMLAttributes } from "react"; +import { BuyCard } from "./buy-card"; +import { cn } from "@cartridge/ui"; + +const MOCKDATA = [ + { + name: "bal7hazar", + percentage: "21%", + percentageChange: "-2.3%", + }, + { + name: "clicksave", + percentage: "12%", + percentageChange: "-1.1%", + }, + { + name: "flipper", + percentage: "8%", + percentageChange: "-0.5%", + }, + { + name: "gamer123", + percentage: "5%", + percentageChange: "-0.2%", + }, + { + name: "proplayer", + percentage: "4%", + percentageChange: "-0.1%", + }, +]; + +export const BuySection = React.forwardRef< + HTMLDivElement, + HTMLAttributes +>(({ className }, ref) => { + return ( +
+ {MOCKDATA.map((item, index) => ( + + ))} +
+ ); +}); diff --git a/client/src/components/prediction/chart.tsx b/client/src/components/prediction/chart.tsx new file mode 100644 index 00000000..57cf5ea6 --- /dev/null +++ b/client/src/components/prediction/chart.tsx @@ -0,0 +1,205 @@ +import { useRef, useMemo, useEffect, useCallback } from "react"; +import { + Chart as ChartJS, + CategoryScale, + LinearScale, + PointElement, + LineElement, + Tooltip, + Legend, + ChartOptions, + ScriptableContext, +} from "chart.js"; +import { Line } from "react-chartjs-2"; +import { UserAvatar } from "../user/avatar"; + +// Register Chart.js components +ChartJS.register( + CategoryScale, + LinearScale, + PointElement, + LineElement, + Tooltip, + Legend, +); + +export interface Player { + name: string; + color: string; + baseValue: number; // Base percentage value around which to randomize + variance: number; // Amount of randomization (+/-) +} + +interface ChartData { + day: number; + playerData: Record; +} + +export interface PredictionPageProps { + players?: Player[]; +} + +export function MarketChart({ players }: PredictionPageProps) { + const chartRef = useRef>(null); + + // Default players if none provided + const defaultPlayers: Player[] = [ + { name: "bal7hazar", color: "#60A5FA", baseValue: 20, variance: 4 }, + { name: "clicksave", color: "#FB923C", baseValue: 11, variance: 3 }, + { name: "flipper", color: "#4ADE80", baseValue: 7, variance: 3 }, + ]; + + const activePlayers = players || defaultPlayers; + + // Generate 7 days of mock data ending with today + const generateMockData = useCallback((): ChartData[] => { + const data: ChartData[] = []; + const today = new Date(); + + for (let i = 6; i >= 0; i--) { + const date = new Date(today); + date.setDate(date.getDate() - i); + const day = date.getDate(); + + const playerData: Record = {}; + activePlayers.forEach((player) => { + playerData[player.name] = + player.baseValue + (Math.random() - 0.5) * 2 * player.variance; + }); + + data.push({ + day, + playerData, + }); + } + + return data; + }, [activePlayers]); + + const chartData = useMemo(() => { + const mockData = generateMockData(); + + return { + labels: mockData.map((d) => d.day.toString()), + datasets: activePlayers.map((player) => ({ + label: player.name, + data: mockData.map((d) => d.playerData[player.name]), + borderColor: player.color, + backgroundColor: player.color, + borderWidth: 1, + pointRadius: (ctx: ScriptableContext<"line">) => { + // Only show point at the last data point + return ctx.dataIndex === ctx.dataset.data.length - 1 ? 3 : 0; + }, + pointHoverRadius: 6, + fill: false, + })), + }; + }, [activePlayers, generateMockData]); + + const options = useMemo((): ChartOptions<"line"> => { + return { + responsive: true, + maintainAspectRatio: false, + plugins: { + legend: { + display: false, // We'll create custom legend + }, + tooltip: { + backgroundColor: "#1F2937", + titleColor: "#F9FAFB", + bodyColor: "#F9FAFB", + borderColor: "#374151", + borderWidth: 1, + callbacks: { + label: (context) => { + return `${context.dataset.label}: ${context.parsed.y.toFixed(1)}%`; + }, + }, + }, + }, + scales: { + x: { + grid: { + display: false, + color: "rgba(255, 255, 255, 0.1)", + }, + border: { + display: false, + }, + ticks: { + color: "#505050", + font: { + size: 12, + }, + }, + }, + y: { + position: "right", + min: 0, + max: 28, + grid: { + display: false, + color: "rgba(255, 255, 255, 0.1)", + }, + border: { + display: false, + }, + ticks: { + color: "#505050", + font: { + size: 12, + }, + callback: (value) => `${value}%`, + stepSize: 7, + }, + }, + }, + interaction: { + intersect: false, + mode: "index", + }, + }; + }, []); + + // Handle chart resize + useEffect(() => { + const handleResize = () => { + if (chartRef.current) { + chartRef.current.resize(); + } + }; + + window.addEventListener("resize", handleResize); + return () => window.removeEventListener("resize", handleResize); + }, []); + + return ( + <> + {/* Legend */} +
+ {activePlayers.map((player) => ( +
+
+ + + {player.name} + +
+ ))} +
+ + {/* Chart Container */} +
+ +
+ + ); +} diff --git a/client/src/components/prediction/comment-row.tsx b/client/src/components/prediction/comment-row.tsx new file mode 100644 index 00000000..462c6ab0 --- /dev/null +++ b/client/src/components/prediction/comment-row.tsx @@ -0,0 +1,45 @@ +import { cn, Thumbnail } from "@cartridge/ui"; +import React, { HTMLAttributes } from "react"; +import { UserAvatar } from "../user/avatar"; + +export interface CommentRowProps { + name: string; + comment: string; + timestamp: string; +} + +export const CommentRow = React.forwardRef< + HTMLDivElement, + HTMLAttributes & CommentRowProps +>(({ className, name, comment, timestamp, ...props }, ref) => { + return ( +
+
+ } + rounded + size="md" + variant="lighter" + /> +
+
+

{name}

+
+

{comment}

+
+
+
+

+ {timestamp} +

+
+
+ ); +}); diff --git a/client/src/components/prediction/header.tsx b/client/src/components/prediction/header.tsx new file mode 100644 index 00000000..3950bffd --- /dev/null +++ b/client/src/components/prediction/header.tsx @@ -0,0 +1,89 @@ +import { Button, ClockIcon, cn, Thumbnail, TimesIcon } from "@cartridge/ui"; +import { UserAvatar } from "../user/avatar"; +import React, { HTMLAttributes, useCallback } from "react"; +import { useLocation, useNavigate } from "react-router-dom"; + +export const PredictionHeader = React.forwardRef< + HTMLDivElement, + HTMLAttributes +>(({ className, ...props }, ref) => { + const location = useLocation(); + const navigate = useNavigate(); + + const handleClose = useCallback(() => { + let pathname = location.pathname; + pathname = pathname.replace(/\/tab\/prediction-[^/]+$/, ""); + pathname = pathname.replace(/\/prediction$/, ""); + navigate(pathname || "/"); + }, [location, navigate]); + + return ( +
+
+
+ +
+

+ Blitz Edition Season 1 +

+
+
+
+ +

+ 8,800 TVL +

+
+
+
+
+
+ Created by +
+ +
+ flipper +
+
+
+
+
+ +

2d 12h 5m

+
+
+
+
+
+
+ +
+ ); +}); + +function CloseButton({ handleClose }: { handleClose: () => void }) { + return ( + + ); +} diff --git a/client/src/components/prediction/holder-label.tsx b/client/src/components/prediction/holder-label.tsx new file mode 100644 index 00000000..d17f410a --- /dev/null +++ b/client/src/components/prediction/holder-label.tsx @@ -0,0 +1,40 @@ +import { cn } from "@cartridge/ui"; +import React, { HTMLAttributes } from "react"; + +export const HolderLabel = React.forwardRef< + HTMLDivElement, + HTMLAttributes +>(({ className, ...props }, ref) => { + return ( +
+
+
+ # +
+ +
+ Owner +
+
+ +
+
+ + Shares + +
+ +
+ + % Held + +
+
+
+ ); +}); diff --git a/client/src/components/prediction/holder-row.tsx b/client/src/components/prediction/holder-row.tsx new file mode 100644 index 00000000..db0e573f --- /dev/null +++ b/client/src/components/prediction/holder-row.tsx @@ -0,0 +1,47 @@ +import { cn } from "@cartridge/ui"; +import React, { HTMLAttributes } from "react"; +import { UserAvatar } from "../user/avatar"; + +export interface THolders { + order?: number; + ownerName: string; + shares: number; + percentHeld: number; +} + +export const HolderRow = React.forwardRef< + HTMLDivElement, + HTMLAttributes & THolders +>(({ className, ownerName, shares, percentHeld, order, ...props }, ref) => { + return ( +
+
+

{order}.

+
+ +

{ownerName}

+
+
+
+
+ +

{shares}

+
+ +
+

{percentHeld}%

+
+
+
+ ); +}); diff --git a/client/src/components/prediction/index.ts b/client/src/components/prediction/index.ts new file mode 100644 index 00000000..93e16c3e --- /dev/null +++ b/client/src/components/prediction/index.ts @@ -0,0 +1,4 @@ +export * from "./buy-card"; +export * from "./buy-section"; +export * from "./chart"; +export * from "./prediction-tabs"; diff --git a/client/src/components/prediction/positions-label.tsx b/client/src/components/prediction/positions-label.tsx new file mode 100644 index 00000000..d9d0eacf --- /dev/null +++ b/client/src/components/prediction/positions-label.tsx @@ -0,0 +1,32 @@ +import { cn } from "@cartridge/ui"; +import React, { HTMLAttributes } from "react"; + +export const PositionsLabel = React.forwardRef< + HTMLDivElement, + HTMLAttributes +>(({ className, ...props }, ref) => { + return ( +
+
+
+ + Market + +
+
+ +
+ Balance +
+ +
+ To Earn +
+
+ ); +}); diff --git a/client/src/components/prediction/positions-row.tsx b/client/src/components/prediction/positions-row.tsx new file mode 100644 index 00000000..804eec5a --- /dev/null +++ b/client/src/components/prediction/positions-row.tsx @@ -0,0 +1,87 @@ +import { Thumbnail } from "@cartridge/ui"; +import { UserAvatar } from "../user/avatar"; +import { cn } from "@/lib/utils"; +import React from "react"; + +export interface PredictionPositionCardProps { + description: string; + + // User Info + username: string; + userAvatarClassName: string; + + // Balance Token/Asset Info + balanceTokenIcon: string; + balanceTokenAmount: string | number; + + // To Earn Token/Asset Info + earnTokenIcon: string; + earnTokenAmount: string | number; +} + +export const PredictionPositionCard = React.forwardRef< + HTMLDivElement, + React.HTMLAttributes & PredictionPositionCardProps +>( + ( + { + description, + username, + userAvatarClassName, + balanceTokenIcon, + balanceTokenAmount, + earnTokenIcon, + earnTokenAmount, + className, + ...props + }, + ref, + ) => { + return ( +
+
+
+
+
+ +
+

{username}

+
+
+

+ {description} +

+
+
+
+ +
+ +

+ {balanceTokenAmount.toLocaleString()} +

+
+ +
+ +

+ {earnTokenAmount.toLocaleString()} +

+
+
+ ); + }, +); diff --git a/client/src/components/prediction/prediction-tabs.tsx b/client/src/components/prediction/prediction-tabs.tsx new file mode 100644 index 00000000..46f17571 --- /dev/null +++ b/client/src/components/prediction/prediction-tabs.tsx @@ -0,0 +1,61 @@ +import { TabsContent } from "@cartridge/ui"; +import { ArcadeTabs, TabValue } from "../modules"; +import { PredictionActivityScene } from "../scenes/prediction-activity"; +import { PredictionHoldersScene } from "../scenes/prediction-holders"; +import { PredictionCommentsScene } from "../scenes/prediction-comments"; +import { PredictionPositionsScene } from "../scenes/prediction-positions"; + +export interface PredictionTabsProps { + defaultValue?: TabValue; + onTabClick?: (tab: TabValue) => void; +} + +export function PredictionTabs({ + defaultValue = "prediction-activity", + onTabClick, +}: PredictionTabsProps) { + const order: TabValue[] = [ + "prediction-activity", + "prediction-holders", + "prediction-comments", + "prediction-positions", + ]; + + return ( +
+ +
+ + + + + + + + + + + + +
+
+
+ ); +} diff --git a/client/src/components/scenes/prediction-activity.tsx b/client/src/components/scenes/prediction-activity.tsx new file mode 100644 index 00000000..cebaf2c3 --- /dev/null +++ b/client/src/components/scenes/prediction-activity.tsx @@ -0,0 +1,18 @@ +import { PredictionActivityFeed } from "../prediction/activity-feed"; + +const MOCKDATA = { + username: "fortunaragem", + total: 100, + itemName: "shinobi", + timestamp: "2 days ago", +}; + +export const PredictionActivityScene = () => { + return ( +
+ {Array.from({ length: 5 }).map((_, index) => ( + + ))} +
+ ); +}; diff --git a/client/src/components/scenes/prediction-comments.tsx b/client/src/components/scenes/prediction-comments.tsx new file mode 100644 index 00000000..0fdc93e5 --- /dev/null +++ b/client/src/components/scenes/prediction-comments.tsx @@ -0,0 +1,81 @@ +import { Button, Input } from "@cartridge/ui"; +import { CommentRow, CommentRowProps } from "../prediction/comment-row"; +import { useCallback, useState } from "react"; +import { useUsername } from "@/hooks/account"; +import { useAddress } from "@/hooks/address"; + +const MOCKDATA = [ + { + name: "tedison", + comment: "clicksave's got it in the bag", + timestamp: "2s ago", + }, + { + name: "glihm", + comment: "clicksave's got it in the bag", + timestamp: "2s ago", + }, + { + name: "kariy", + comment: "clicksave's got it in the bag", + timestamp: "2s ago", + }, + { + name: "ashe", + comment: "clicksave's got it in the bag", + timestamp: "2s ago", + }, + { + name: "flipper", + comment: "clicksave's got it in the bag", + timestamp: "2s ago", + }, +] satisfies Array; + +export const PredictionCommentsScene = () => { + const [comments, setComments] = useState>(MOCKDATA); + const { address } = useAddress(); + const { username } = useUsername({ address }); + + const handleAddComment = useCallback( + (newComment: CommentRowProps) => { + setComments([newComment, ...comments]); + }, + [comments], + ); + + return ( +
+
{ + e.preventDefault(); + + if (!e.currentTarget[0]) return; + + const body = { + name: username || "Anonymous", + comment: (e.currentTarget[0] as HTMLInputElement).value, + timestamp: "Just now", + } satisfies CommentRowProps; + return handleAddComment(body); + }} + className="flex flex-row gap-4 w-full" + > +
+ +
+ +
+ + {comments.map((comment, index) => ( + + ))} +
+ ); +}; diff --git a/client/src/components/scenes/prediction-holders.tsx b/client/src/components/scenes/prediction-holders.tsx new file mode 100644 index 00000000..f0209e87 --- /dev/null +++ b/client/src/components/scenes/prediction-holders.tsx @@ -0,0 +1,54 @@ +import { HolderLabel } from "../prediction/holder-label"; +import { HolderRow, THolders } from "../prediction/holder-row"; + +const MOCKDATA = [ + { + ownerName: "tedison", + shares: 100, + percentHeld: 20, + }, + { + ownerName: "fortunaregem", + shares: 100, + percentHeld: 14, + }, + { + ownerName: "bal7hazar", + shares: 100, + percentHeld: 12, + }, + { + ownerName: "tarrence", + shares: 100, + percentHeld: 8, + }, + { + ownerName: "raschel0x", + shares: 100, + percentHeld: 4, + }, + { + ownerName: "load69", + shares: 100, + percentHeld: 2, + }, + { + ownerName: "clicksave", + shares: 100, + percentHeld: 1, + }, +] satisfies Array; + +export const PredictionHoldersScene = () => { + return ( +
+ + +
+ {MOCKDATA.map((holder, index) => ( + + ))} +
+
+ ); +}; diff --git a/client/src/components/scenes/prediction-positions.tsx b/client/src/components/scenes/prediction-positions.tsx new file mode 100644 index 00000000..3e5aba66 --- /dev/null +++ b/client/src/components/scenes/prediction-positions.tsx @@ -0,0 +1,51 @@ +import { PositionsLabel } from "../prediction/positions-label"; +import { PredictionPositionCard } from "../prediction/positions-row"; + +const MOCKDATA = [ + { + description: "to win Season 1 of Blitz Eternum", + + // User Info + username: "bal7hazar", + userAvatarClassName: "", + + // Balance Token/Asset Info + balanceTokenIcon: + "https://imagedelivery.net/0xPAQaDtnQhBs8IzYRIlNg/a3bfe959-50c4-4f89-0aef-b19207d82a00/logo", + balanceTokenAmount: 902, + + // To Earn Token/Asset Info + earnTokenIcon: + "https://imagedelivery.net/0xPAQaDtnQhBs8IzYRIlNg/a3bfe959-50c4-4f89-0aef-b19207d82a00/logo", + earnTokenAmount: 6300, + }, + { + description: "to win Season 1 of Blitz Eternum", + + // User Info + username: "clicksave", + userAvatarClassName: "", + + // Balance Token/Asset Info + balanceTokenIcon: + "https://imagedelivery.net/0xPAQaDtnQhBs8IzYRIlNg/a3bfe959-50c4-4f89-0aef-b19207d82a00/logo", + balanceTokenAmount: 902, + + // To Earn Token/Asset Info + earnTokenIcon: + "https://imagedelivery.net/0xPAQaDtnQhBs8IzYRIlNg/a3bfe959-50c4-4f89-0aef-b19207d82a00/logo", + earnTokenAmount: 6300, + }, +]; + +export const PredictionPositionsScene = () => { + return ( +
+ + + {MOCKDATA.map((item, index) => ( + + ))} +
+ ); +}; diff --git a/client/src/hooks/project.ts b/client/src/hooks/project.ts index 5782d2a8..af9c374f 100644 --- a/client/src/hooks/project.ts +++ b/client/src/hooks/project.ts @@ -34,7 +34,7 @@ export const useProject = () => { tab: string; }>(); - const [searchParams, _] = useSearchParams(); + const [searchParams] = useSearchParams(); const filter = useMemo(() => { return searchParams.get("filter"); diff --git a/client/src/main.tsx b/client/src/main.tsx index fae9c2ef..c86e1bb5 100644 --- a/client/src/main.tsx +++ b/client/src/main.tsx @@ -17,6 +17,9 @@ createRoot(document.getElementById("root")!).render( }> } /> + }> + } /> + }> } /> diff --git a/client/tsconfig.app.tsbuildinfo b/client/tsconfig.app.tsbuildinfo index ea11f913..2baa5ba3 100644 --- a/client/tsconfig.app.tsbuildinfo +++ b/client/tsconfig.app.tsbuildinfo @@ -1 +1 @@ -{"root":["./src/constants.ts","./src/main.tsx","./src/vite-env.d.ts","./src/components/app.tsx","./src/components/header.tsx","./src/components/sidebar-toggle.tsx","./src/components/about/details.tsx","./src/components/about/index.tsx","./src/components/about/media.tsx","./src/components/about/metrics.tsx","./src/components/about/youtube-icon.tsx","./src/components/achievements/index.tsx","./src/components/achievements/trophies.tsx","./src/components/activity/index.tsx","./src/components/connection/connect.tsx","./src/components/connection/index.tsx","./src/components/connection/user.tsx","./src/components/discover/index.tsx","./src/components/editions/form.tsx","./src/components/editions/index.tsx","./src/components/editions/prioritize.tsx","./src/components/editions/publish.tsx","./src/components/editions/register.tsx","./src/components/editions/whitelist.tsx","./src/components/errors/index.tsx","./src/components/filters/index.tsx","./src/components/games/data.ts","./src/components/games/index.tsx","./src/components/games/publish.tsx","./src/components/games/register-form.tsx","./src/components/games/register.tsx","./src/components/games/update-form.tsx","./src/components/games/update.tsx","./src/components/games/whitelist.tsx","./src/components/guilds/index.tsx","./src/components/holders/index.tsx","./src/components/inventory/collections.tsx","./src/components/inventory/index.tsx","./src/components/inventory/tokens.tsx","./src/components/items/index.tsx","./src/components/leaderboard/index.tsx","./src/components/marketplace/index.tsx","./src/components/modules/achievement-card.tsx","./src/components/modules/achievement-pin-icon.tsx","./src/components/modules/achievement-pin-icons.tsx","./src/components/modules/activity-achievement-card.tsx","./src/components/modules/arcade-header.tsx","./src/components/modules/controller-action.tsx","./src/components/modules/controller-actions.tsx","./src/components/modules/copy-address.tsx","./src/components/modules/discovery-event.tsx","./src/components/modules/discovery-group.tsx","./src/components/modules/edition-actions.tsx","./src/components/modules/edition-item.tsx","./src/components/modules/follow-tag.tsx","./src/components/modules/game-header.tsx","./src/components/modules/game-select.tsx","./src/components/modules/game-social.tsx","./src/components/modules/game-socials.tsx","./src/components/modules/index.ts","./src/components/modules/layout-bottom-tabs.tsx","./src/components/modules/leaderboard-row.tsx","./src/components/modules/leaderboard-username.tsx","./src/components/modules/menu-button.tsx","./src/components/modules/menu-item.tsx","./src/components/modules/player-header.tsx","./src/components/modules/player-label.tsx","./src/components/modules/sub-tab.tsx","./src/components/modules/sub-tabs.tsx","./src/components/modules/summary.tsx","./src/components/modules/tab.tsx","./src/components/modules/tabs.tsx","./src/components/navigation/index.tsx","./src/components/pages/game.tsx","./src/components/pages/market.tsx","./src/components/pages/player.tsx","./src/components/positions/column-labels.tsx","./src/components/positions/index.tsx","./src/components/positions/position-card.tsx","./src/components/predict/index.tsx","./src/components/predict/predict-card.tsx","./src/components/scenes/about.tsx","./src/components/scenes/achievement.tsx","./src/components/scenes/activity.tsx","./src/components/scenes/discover.tsx","./src/components/scenes/guild.tsx","./src/components/scenes/holders.tsx","./src/components/scenes/inventory.tsx","./src/components/scenes/items.tsx","./src/components/scenes/layout.tsx","./src/components/scenes/leaderboard.tsx","./src/components/scenes/marketplace.tsx","./src/components/scenes/positions.tsx","./src/components/scenes/predict.tsx","./src/components/scenes/traceability.tsx","./src/components/traceability/index.tsx","./src/components/ui/button.tsx","./src/components/ui/carousel.tsx","./src/components/ui/form.tsx","./src/components/ui/label.tsx","./src/components/ui/pagination.tsx","./src/components/user/avatar.tsx","./src/components/user/user-card.tsx","./src/context/achievement.tsx","./src/context/activities.tsx","./src/context/arcade.tsx","./src/context/collection.tsx","./src/context/discovers.tsx","./src/context/index.tsx","./src/context/market-collection.tsx","./src/context/market-filters.tsx","./src/context/marketplace.tsx","./src/context/metrics.tsx","./src/context/ownerships.tsx","./src/context/posthog.tsx","./src/context/provider.tsx","./src/context/sidebar.tsx","./src/context/starknet.tsx","./src/context/theme.tsx","./src/context/token.tsx","./src/helpers/achievements.ts","./src/helpers/index.ts","./src/helpers/metadata.tsx","./src/hooks/account.ts","./src/hooks/achievements.ts","./src/hooks/activities.ts","./src/hooks/address.ts","./src/hooks/arcade.ts","./src/hooks/collections.ts","./src/hooks/context.ts","./src/hooks/device.ts","./src/hooks/discovers.ts","./src/hooks/market-collections.ts","./src/hooks/market-filters.ts","./src/hooks/marketplace.ts","./src/hooks/metrics.ts","./src/hooks/ownerships.ts","./src/hooks/progressions.ts","./src/hooks/project.ts","./src/hooks/sidebar.ts","./src/hooks/token-fetcher.ts","./src/hooks/tokens.ts","./src/hooks/trophies.ts","./src/icons/branch.tsx","./src/lib/utils.ts","./src/models/index.ts","./src/models/progress.ts","./src/models/trophy.ts"],"version":"5.9.2"} \ No newline at end of file +{"root":["./src/constants.ts","./src/main.tsx","./src/vite-env.d.ts","./src/components/app.tsx","./src/components/header.tsx","./src/components/sidebar-toggle.tsx","./src/components/about/details.tsx","./src/components/about/index.tsx","./src/components/about/media.tsx","./src/components/about/metrics.tsx","./src/components/about/youtube-icon.tsx","./src/components/achievements/index.tsx","./src/components/achievements/trophies.tsx","./src/components/activity/index.tsx","./src/components/connection/connect.tsx","./src/components/connection/index.tsx","./src/components/connection/user.tsx","./src/components/discover/index.tsx","./src/components/editions/form.tsx","./src/components/editions/index.tsx","./src/components/editions/prioritize.tsx","./src/components/editions/publish.tsx","./src/components/editions/register.tsx","./src/components/editions/whitelist.tsx","./src/components/errors/index.tsx","./src/components/filters/index.tsx","./src/components/games/data.ts","./src/components/games/index.tsx","./src/components/games/prediction-sidebar.tsx","./src/components/games/publish.tsx","./src/components/games/register-form.tsx","./src/components/games/register.tsx","./src/components/games/update-form.tsx","./src/components/games/update.tsx","./src/components/games/whitelist.tsx","./src/components/guilds/index.tsx","./src/components/holders/index.tsx","./src/components/inventory/collections.tsx","./src/components/inventory/index.tsx","./src/components/inventory/tokens.tsx","./src/components/items/index.tsx","./src/components/leaderboard/index.tsx","./src/components/marketplace/index.tsx","./src/components/modules/achievement-card.tsx","./src/components/modules/achievement-pin-icon.tsx","./src/components/modules/achievement-pin-icons.tsx","./src/components/modules/activity-achievement-card.tsx","./src/components/modules/arcade-header.tsx","./src/components/modules/controller-action.tsx","./src/components/modules/controller-actions.tsx","./src/components/modules/copy-address.tsx","./src/components/modules/discovery-event.tsx","./src/components/modules/discovery-group.tsx","./src/components/modules/edition-actions.tsx","./src/components/modules/edition-item.tsx","./src/components/modules/follow-tag.tsx","./src/components/modules/game-header.tsx","./src/components/modules/game-select.tsx","./src/components/modules/game-social.tsx","./src/components/modules/game-socials.tsx","./src/components/modules/index.ts","./src/components/modules/layout-bottom-tabs.tsx","./src/components/modules/leaderboard-row.tsx","./src/components/modules/leaderboard-username.tsx","./src/components/modules/menu-button.tsx","./src/components/modules/menu-item.tsx","./src/components/modules/player-header.tsx","./src/components/modules/player-label.tsx","./src/components/modules/sub-tab.tsx","./src/components/modules/sub-tabs.tsx","./src/components/modules/summary.tsx","./src/components/modules/tab.tsx","./src/components/modules/tabs.tsx","./src/components/navigation/index.tsx","./src/components/pages/game.tsx","./src/components/pages/market.tsx","./src/components/pages/player.tsx","./src/components/pages/prediction.tsx","./src/components/positions/column-labels.tsx","./src/components/positions/index.tsx","./src/components/positions/position-card.tsx","./src/components/predict/index.tsx","./src/components/predict/predict-card.tsx","./src/components/prediction/activity-feed.tsx","./src/components/prediction/buy-card.tsx","./src/components/prediction/buy-section.tsx","./src/components/prediction/chart.tsx","./src/components/prediction/comment-row.tsx","./src/components/prediction/header.tsx","./src/components/prediction/holder-label.tsx","./src/components/prediction/holder-row.tsx","./src/components/prediction/index.ts","./src/components/prediction/positions-label.tsx","./src/components/prediction/positions-row.tsx","./src/components/prediction/prediction-tabs.tsx","./src/components/scenes/about.tsx","./src/components/scenes/achievement.tsx","./src/components/scenes/activity.tsx","./src/components/scenes/discover.tsx","./src/components/scenes/guild.tsx","./src/components/scenes/holders.tsx","./src/components/scenes/inventory.tsx","./src/components/scenes/items.tsx","./src/components/scenes/layout.tsx","./src/components/scenes/leaderboard.tsx","./src/components/scenes/marketplace.tsx","./src/components/scenes/positions.tsx","./src/components/scenes/predict.tsx","./src/components/scenes/prediction-activity.tsx","./src/components/scenes/prediction-comments.tsx","./src/components/scenes/prediction-holders.tsx","./src/components/scenes/prediction-positions.tsx","./src/components/scenes/traceability.tsx","./src/components/traceability/index.tsx","./src/components/ui/button.tsx","./src/components/ui/carousel.tsx","./src/components/ui/form.tsx","./src/components/ui/label.tsx","./src/components/ui/pagination.tsx","./src/components/user/avatar.tsx","./src/components/user/user-card.tsx","./src/context/achievement.tsx","./src/context/activities.tsx","./src/context/arcade.tsx","./src/context/collection.tsx","./src/context/discovers.tsx","./src/context/index.tsx","./src/context/market-collection.tsx","./src/context/market-filters.tsx","./src/context/marketplace.tsx","./src/context/metrics.tsx","./src/context/ownerships.tsx","./src/context/posthog.tsx","./src/context/provider.tsx","./src/context/sidebar.tsx","./src/context/starknet.tsx","./src/context/theme.tsx","./src/context/token.tsx","./src/helpers/achievements.ts","./src/helpers/index.ts","./src/helpers/metadata.tsx","./src/hooks/account.ts","./src/hooks/achievements.ts","./src/hooks/activities.ts","./src/hooks/address.ts","./src/hooks/arcade.ts","./src/hooks/collections.ts","./src/hooks/context.ts","./src/hooks/device.ts","./src/hooks/discovers.ts","./src/hooks/market-collections.ts","./src/hooks/market-filters.ts","./src/hooks/marketplace.ts","./src/hooks/metrics.ts","./src/hooks/ownerships.ts","./src/hooks/progressions.ts","./src/hooks/project.ts","./src/hooks/sidebar.ts","./src/hooks/token-fetcher.ts","./src/hooks/tokens.ts","./src/hooks/trophies.ts","./src/icons/branch.tsx","./src/lib/utils.ts","./src/models/index.ts","./src/models/progress.ts","./src/models/trophy.ts"],"version":"5.9.2"} \ No newline at end of file